草庐IT

test_union

全部标签

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++ - 这是 union 的正确用法吗

我想要命名字段而不是索引字段,但对于某些用途我必须迭代字段。愚蠢的简化示例:structnamed_states{floatspeed;floatposition;};#defineNSTATES(sizeof(structnamed_states)/sizeof(float))unionnamed_or_indexed_states{structnamed_statesnamed;floatindexed[NSTATES];}...unionnamed_or_indexed_statesstates,derivatives;states.named.speed=0;states.na

c++ - union 中的标量成员是否计入公共(public)初始序列?

在下面的unionU中,如果a或b是活跃成员,是否定义了访问c?structA{inta;};structB{inta;doubleb;};unionU{Aa;Bb;intc;};在[class.union],该标准定义了一些规则,使使用union更容易(强调我的):[ Note:Onespecialguaranteeismadeinordertosimplifytheuseofunions:Ifastandard-layoutunioncontainsseveralstandard-layoutstructsthatshareacommoninitialsequence,andifa

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++:包含类实例的 union 会调用错误的虚函数

我在运行以下代码时遇到了一个奇怪的现象:#includeclassPiece{public:classQueen;classKnight;unionAny;virtualconstchar*name()const=0;};classPiece::Queen:publicPiece{public:virtualconstchar*name()const{return"Queen";}};classPiece::Knight:publicPiece{public:virtualconstchar*name()const{return"Knight";}};unionPiece::Any{p

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++ - C/C++ union 和未定义行为

以下是未定义的行为吗?union{intfoo;floatbar;}baz;baz.foo=3.14*baz.bar;我记得在两个序列点之间写入和读取同一底层内存是UB,但我不确定。 最佳答案 IrememberthatwritingandreadingfromthesameunderlyingmemorybetweentwosequencepointsisUB,butIamnotcertain.读取和写入同一表达式中的同一内存位置不会调用未定义的行为,除非该位置在两个序列点之间被修改多次,或者副作用相对于使用值计算的值是无序的相同

c++ - 在这种情况下,C++ 中的 union 做了什么?

在我工作的其中一个类中,我在头文件中发现了类似这样的内容://Flagsunion{DWORD_flags;struct{unsigned_fVar1:1;unsigned_fVar2:1;unsigned_fVar3:1;unsigned_fVar4:1;};};在一些类的成员函数中,我看到_flags被直接设置为_flags=3;。我还看到结构中的成员被直接设置,例如_fVar1=0并与之进行比较。我正在尝试删除_fVar1,我不确定它会对访问_flags和其他_fVar#的其他地方做什么或设置。例如,设置_flags=3是否意味着_fVar1和_fVar2将为1而_fVar3和_