草庐IT

bool_test

全部标签

c++ - 如何在 Parasoft C++test 中将函数标记为不返回?

我们有一个die函数输出错误信息并退出,例如:voiddie(constchar*msg){fprintf(stderr,"Error:%s\n",msg);exit(1);}我们使用ParasoftC++test静态分析我们的代码,但它没有意识到die是一个非返回函数。所以当它看到如下代码时:voidfoo(Bar*bar){if(!bar){die("barisNULL");}Barbar2=*bar;}它警告*bar可能正在取消引用空指针,即使bar为NULL会阻止该行执行。有没有办法以Parasoft可以识别的方式将die标记为不返回?编辑:我需要在GCC和VS2003中都能工

c++ - 如何预期 static_assert 失败并使用 Boost.Test 框架处理它?

如果我有一个接受模板参数的方法,该模板参数应该可转换为base_of或与返回类型相同的类型,我应该怎么做?例如,考虑这个方法:templateclassIFoo{public:templateT*as(){static_assert(std::is_same::value||std::is_convertible::value||std::is_base_of::value,"IFoo::as()requiresServiceTtobeabaseofT");...}};现在,我想对其进行BOOST_CHECK!classA{};classB{};BOOST_AUTO_TEST_CASE

c++ - 未在 lambda 内部调用显式运算符 bool — MSVC 错误?

#includestructT{explicitoperatorbool(){returntrue;}};intmain(){Tt;if(t){}//OKautol=[&](){if(t){}//Error};}MSVC的行为在这里似乎奇怪地不一致;OK行和Error行之间的唯一区别是它们在lambda中。这是错误吗? 最佳答案 Isthisabug?是的,绝对是。您的程序没有任何问题,bool转换运算符在两种情况下都应被调用。 关于c++-未在lambda内部调用显式运算符bool—M

c++ - 为什么显式运算符 bool 让我转换为任何原始类型?

structtest{explicitoperatorbool()const{returntrue;}};intmain(){testa;floatb=static_cast(a);//b=1}这是正确的,还是一个VS错误?如果按照设计,这里的最佳做法是什么?我应该/可以做些什么来防止这种情况发生吗? 最佳答案 这看起来像一个VS错误:显式运算符不应该应用于bool以外的类型。在这两个C++11mode中都无法在gcc中编译和C++98mode.CanIdoanythingtopreventthis?您已经完成了您需要做的事情-这是

c++ - 在 C++ 标准中哪里说 sizeof(wchar_t) <= sizeof(long) 和 sizeof(bool) <= sizeof(long)?

先生。Stroustrup在他的新书(TCPL第4版)第149页写下了以下内容1我在标准中找不到任何支持上面最后一个不等式的内容。我可以对sizeof(bool)说同样的话.编辑:在3.9.1p5你会发现:Typewchar_tshallhavethesamesize,signedness,andalignmentrequirements(3.11)asoneoftheotherintegraltypes,calleditsunderlyingtype.支持不平等sizeof(wchar_t)但不是sizeof(wchar_t)但是我找不到任何可以证实的东西sizeof(bool)

c++ - 在 C、C++ 中将 bool 变量与 1 和 0 进行比较是否安全?

这个问题在这里已经有了答案:CanIassume(bool)true==(int)1foranyC++compiler?(5个答案)关闭8年前。考虑代码boolf(){return42;}if(f()==1)printf("hello");C(带有stdbool.h的C99+)和C++标准是否保证会打印“hello”?做boola=x;总是等同于boola=x?1:0;

c++ - 避免在静态 bool 值上使用 if 语句进行逻辑决策

我有一个类,其成员itemType仅设置一次且从未修改过,但在许多if语句中使用它来决定调用哪个函数。由于itemType仅设置一次,因此有办法避免类中其他地方的if语句。这将简化和清理代码,并且作为奖励还将节省if检查的开销。我正在考虑一个指针函数,我可以根据itemType值在构造函数中初始化它。有没有更好的替代方法?请注意原始类和代码库很大,我无法根据项目类型创建子类。enumItemTypes{ItemTypeA,ItemTypeB,};classItemProcessing{public://ThisfunctioniscalledhundredsoftimesvoidPro

c++ - ifstream.good() 和 bool(ifstream) 的区别

我正在编写一个程序,它从一个文本文件中获取多个变量。当程序发现EOF时,它结束输入数据。intmain(){intval,count=0;ifstreamfileIn;fileIn.open("num.txt");fileIn>>val;while(fileIn){++count;cout>val;}coutnum.txt文件:11223344程序输出:number:11number:22number:33number:44count:4一切正常。但是,如果我将while条件部分从fileIn更改为fileIn.good(),程序输出将如下所示:number:11number:22nu

c++ - 如何使用 bool 模板参数启用成员函数?

我希望一个类有两种不同的push实现,并根据bool模板参数进行选择。我尝试使用thisanswer中描述的SFINAE原理,像这样:templateclassBar{templatetypenamestd::enable_if::typepush(constT&value){/*oneimplementation*/}templatetypenamestd::enable_if::typepush(constT&value){/*anotherimplementation*/}}但是,我在gcc下收到“无法在类范围内特化函数push”的错误,我不明白为什么。尽管我的代码与链接答案中的

c++ - 为什么 Google Test/Mock 通过 std::unique_ptr 显示泄露的模拟对象错误?

假设有一个Bar对象,它使用了一个Foo对象。所有权是独占的,因此Bar在其构造函数中将Foo作为std::unique_ptr获取。我想用Google测试框架测试Bar,所以我编写了以下代码:usingnamespacetesting;classFoo{public:virtualintF()=0;};classBar{public:Bar(std::unique_ptr&&foo):m_foo(std::move(foo)){}intB(){returnm_foo->F();}private:std::unique_ptrm_foo;};classMockFoo:publicFoo