草庐IT

boolean_partition_test

全部标签

c++ - boost::unit_test 案例失败,因为子进程以非零值退出

我有以下代码:boolf(){command="mkdir-p/\/\/";result=aSystemCall(command);if(result==...}BOOST_AUTO_TEST_CASE(BadDir){BOOST_CHECK_EQUAL(false,f());}如果我在命令行中执行command,我会收到权限被拒绝的错误。我知道这一点。这正是我想要测试的。aSystemCall将命令作为子进程执行。当child退出时出现此命令的非零错误,aSystemCall返回一个错误。它不会抛出。如果我在命令行中运行BadDir测试用例,aSystemCall之后的代码永远不会执

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++ - 为什么 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

c++ - 设置 Google Test 时找不到 -lgtest

我正在使用GoogleTestforC++并尝试在我的Linux机器上进行设置。我的make文件包含以下代码:CC=g++CFLAGS=-I$(GOOGLETESTDIR)/include-L$(GOOGLETESTDIR)/lib-lgtest-lpthread-WallDEPS=fib.hOBJS=fib.omain.oall:|r6clean:-rm-fr6$(OBJS)%.o:%.cpp$(DEPS)$(CC)-c-o$@$运行make时出现错误:/usr/bin/ld:cannotfind-lgtest我该如何解决这个问题?我对这种测试很陌生,对Linux也很陌生,所以我真的

c++ - 在 set<int> 与 vector<bool> 与 vector<boolean_t> 之间进行选择以用作位图(位集/位数组)

给定一系列索引(标识符),我想将每个索引映射到一个bool值,即://interfacepseudocodeinterfacebitmap{boolidentifier_is_set(unsignedintid_idx)const;voidset_identifier(unsignedintid_idx,boolval)const;};这样我就可以设置和查询每个ID(索引)是否已设置,您更喜欢用什么来实现它?我认为这叫做位数组或位图或位集,如果我错了请纠正我。假设最大标识符是预先确定的并且不大于1e6(1m),可能更小(10k-100k)。(这意味着sizeof(int)*maximu

c++ - 为什么 istream_iterator<string>(ifstream ("test.txt")) 会导致错误?

我尝试编写代码从名为“test.txt”的文件中读取字符串并将字符串写入标准输出。下面的代码运行良好:intmain(){usingnamespacestd;ifstreamfile("test.txt");copy(istream_iterator(file),istream_iterator(),ostream_iterator(cout,""));}但是,通过此修改,代码不再编译:intmain(){usingnamespacestd;copy(istream_iterator(ifstream("test.txt")),//(),ostream_iterator(cout,""

c++ - 为什么 virtual void test()=00 有效但 virtual void test()=+0 和 virtual void test()=-0 无效?

我搜索了一些关于虚函数声明的帖子,相信=0在virtualvoidtest()=0;是固定句法所以virtualvoidtest()=NULL;virtualvoidtest()=false;virtualvoidtest()=1-1;virtualvoidtest()=0.0;和其他声明应该是无效的。但是我发现了virtualvoidtest()=00;virtualvoidtest()=000;virtualvoidtest()=0000;还能编译,为什么?还有,我觉得整数+0和-0其实和0一样(不知道对不对),就像00其实就是0一样,为什么virtualvoidtest()=+0

c++ - 依赖整数 boolean 转换的枚举

在我的编译器项目中,我有一个像这样的枚举enumResult{No,Maybe,Yes};我已将No明确地放在第一个位置,这样我就可以依赖false的boolean值评估。如果我的编译器不确定某事,并且必须等到运行时才知道事实,它的分析函数将返回Maybe。像这样使用if(!typesEqual(t1,t2)){diagnose(types_unequal)我想知道您或您的公司是否认为不与No明确比较是不好的作风if(typesEqual(t1,t2)==No){/*...*/}明确比较对我来说似乎很罗嗦,但依赖隐式boolean转换不知何故让我感到内疚。您以前有过这种感觉吗?您是如何

c++ - boolean 冒号初始化

在阅读一些C++代码时,我看到了类中的这一行,并对此感到困惑:boolx:1;在调试版本中,我注意到“x”被初始化为“false”,但我找不到任何相关文档。谁能告诉我这个语法的作用? 最佳答案 这是一个位域。阅读您的C++教科书中的位域。false的初始化与声明无关。是否由您的代码保证取决于您的代码(未给出)。C++标准为编译器提供了大小为1的整数和枚举位域的一些余地:在这样的字段中存储值1,您可能会得到值-1。令人高兴的是,这仅适用于大小为1的字段,不适用于bool类型的字段。 关于c