草庐IT

assertion_failed

全部标签

c++ - 为什么 assert 定义为 (void)0?

为什么#defineassert(expression)((void)0),而不是#define断言(表达式)在release模式下使用?(严格来说,定义NDEBUG时)听说是有原因的,忘记了。 最佳答案 ((void)0)定义assert(expression)什么都不做。使用它的主要原因是#defineassert(expression)将允许assert(expression)在没有分号的情况下编译,但如果宏定义为((void)0) 关于c++-为什么assert定义为(void)

c++ - 即时编译 C++ : clang/libtooling fails to set Triple for LLVM IR

假设我想即时编译一个C++字符串:llvm::LLVMContextcontext;std::unique_ptraction=std::make_unique(&context);clang::tooling::runToolOnCode/*WithArgs*/(action.get(),"intfoo(intx){return++x;}");std::unique_ptrmodule=action->takeModule();不幸的是,当LLVM尝试转换IR时,似乎有一个异常表明Triple未设置(https://clang.llvm.org/docs/CrossCompilati

c++ - 浮点相等测试和超精度 : can this code fail?

讨论开始于myanswertoanotherquestion.以下代码确定machineepsilon:floatcompute_eps(){floateps=1.0f;while(1.0f+eps!=1.0f)eps/=2.0f;returneps;}在评论中建议1.0f+eps!=1.0f测试可能会失败,因为C++标准允许使用额外的精度。尽管我知道浮点运算实际上以更高的精度执行(比实际使用的类型指定的精度更高),但我碰巧不同意这个提议。我怀疑在比较操作期间,例如==或!=,操作数没有被截断到它们类型的精度。换句话说,1.0f+eps当然可以比float(例如,longdouble)

鸿蒙真机运行项目报错Failure[INSTALL_FAILED_NO_BUNDLE_SIGNATURE]

错误详情解决方案(给项目加签名)方案一:自动签名使用自动签名前,请确保本地系统时间与北京时间(UTC/GMT+8.00)保持一致。如果不一致,将导致签名失败。1、确保DevEcoStudio与真机设备已连接,真机连接成功后如下图所示:2、打开ProjectStructure3、选中Project>>SigningConfigs>>SignIn 登录自己或者公司的华为的开发者账号(ps:如果是公司开发者建议用公司的开发者账号)4、登录成功返回DevEcoStudio开发工具就会自动加签,点击OK完成5、重新运行项目,真机运行成功,HelloWorld方案二:手动签名

c++ - 使用C++ catch框架验证assert语句

是否可以使用C++CATCH框架来验证assert语句是否正确识别无效前提条件?//SourcecodevoidloadDataFile(FILE*input){assert(input!=NULL);...}//TestcodeTEST_CASE("loadDataFileassertsoutwhenpassedNULL","[loadDataFile]"){loadDataFile(NULL)//NowwhatdoIlookfor?} 最佳答案 假设您的示例的第一部分是被测源代码,第二部分是单元测试,那么您需要选择如何处理:一些

c++ - 索引上的 static_assert 在编译时知道

有没有办法静态断言编译时已知的索引,否则在运行时断言?示例:templateclassFoo{T_data[Dim];public:constT&operator[](intidx)const{static_assert(idxfoo;foo[0];foo[1];foo[2];//compilererrorfor(inti=0;i1}return0;} 最佳答案 您可以简单地抛出异常或断言。它将在constexpr上下文中编译失败。这仅在可以在constexpr上下文中评估抛出条件时才有效。请注意,某些版本的gcc中有一个错误会阻止

c++ - C++如何像Java Spring Assert一样检查条件并抛出异常

有没有标准的方法来做这样的事情?可用于Release模式(NDEBUG定义)检查失败时抛出异常。最好使用标准库或boost。为了清楚起见,我在这里使用的“断言”(可能是不同的术语)特别是关于运行时问题,而不是编程问题,例如SpringAssert。在Java世界中。Microsoft.VisualStudio.TestTools.CppUnitTestFramework是很好的候选人,但它是为了测试目的。 最佳答案 在我的一些项目中我使用:voidASSERT(constboolcond,conststd::string&text)

c++ - 是否可以编写这些 pure_assert 和 const_assert 宏?

GCC__attribute__((pure))和__attribute__((const))分别允许将函数声明为无副作用和引用透明;假设我想编写pure_assert和const_assert宏,其参数必须是适当严格级别的表达式,即:assert(oops_a_side_effect());静默导致调试和发布中的不同行为,但是:pure_assert(oops_a_side_effect());const_assert(oops_read_a_global());至少在调试版本中会出现编译时错误。由于我希望是显而易见的原因,您不能只创建一个声明为__attribute__((pure

c++ - 如何使用 BOOST_STATIC_ASSERT

#include#includeusingnamespacestd;//Iunderstandhowthefollowingtemplatefunctionworks//template//TGetMax(Ta,Tb){//Tresult;//result=(a>b)?a:b;//return(result);//}//Ihavedifficultiestounderstandhowthefollowingcodeworks//whenweshouldusethissyntaxtemplatevoidaccepts_values_between_1_and_10(){BOOST_STA

c++ - 支持逗号和错误信息的自定义 `assert`宏

我想创建一个自定义版本的assert中定义的宏,当断言失败时显示错误消息。所需的用法:custom_assert(AClass::aBoolMethod(),"aBoolMethodmustbetrue");有缺陷的测试实现:#definecustom_assert(mCondition,mMessage)...//ThisfailsbecausemConditionmayhavecommasinit#definecustom_assert(...,mMessage)//Notsureaboutthiseither-mMessagemaybeanexpressioncontaining