草庐IT

mock-maker-inline

全部标签

c++ - `inline` , `constexpr` 或 `noexcept` 仅声明函数

对于没有主体的函数,仅用于类型检查目的或在非评估上下文中,是否有任何冒险将此类函数标记为inline,noexcept或constexpr?例如:namespace_detail{templateconstexprRresult_type(R(T::*)(Params...))noexcept;templateconstexprRresult_type(R(T::*)(Params...)const)noexcept;templateconstexprRresult_type(R(*)(Params...))noexcept;templateconstexprRresult_type(

c++ - 海湾合作委员会 : C++11 inline object initialization (using "this") does not work when there is a virtual inheritance in hierarchy

当在初始化中使用此指针并且在层次结构中存在虚拟继承时,C++11内联对象初始化不起作用(在GCC中)。这可能是GCC的错误吗(因为它在CLang中工作)?还是C++11标准本身的差距?示例(可以在here中尝试),当使用GCC编译以下代码时:FieldIndexm_inB{"inB",this};不会被执行。但它会在使用CLang编译时执行。变通方法:从FieldIndexContainer派生A作为虚拟#include#include#includeusingnamespacestd;classFieldIndexContainer{public:classFieldIndex{pu

C++中的constexpr和inline有何区别与联系?

在C++编程中,constexpr和inline是两个常被用于函数声明的关键字,它们分别有不同的语义和用途,但也可以在某些情况下结合使用。本文将深入探讨constexpr和inline在C++中的区别与联系,以及它们如何影响程序的性能和编译过程。一、constexpr关键字constexpr是C++11引入的一个关键字,用于指定表达式或对象的值在编译时就可以确定。当一个变量或函数被声明为constexpr时,编译器会尝试在编译阶段计算其值,以确保它可以在程序运行时作为一个常量使用。例如:constexprinta=5;//a是一个编译时常量constexprintb=a*2;//b同样是一个编

c++ - 为什么 'outer inline' 模板不编译?

好的,这是一个代码:#includestructA{classType{};templateTypeas(void){std::istringstreamtest;Typetemp;test>>temp;returntemp;}};它编译正常,一点问题都没有。现在,这是几乎相同的代码:#includestructA{classType{};templateinlineTypeas(void);};templateTypeA::as(void){std::istringstreamtest;Typetemp;test>>temp;returntemp;}砰,它不再编译了。错误:t.cc:

C++ ASM Inline如何使用boolean?

说我有这样的东西..boolisPatched;我有一些其他GUI,我在其中设置了isPatched=true;和isPatched=false;,isPatched=!isPatched;void__declspec(naked)test(void){//__asm{PUSHADPUSHFDMOVEAX,isPatchedCMPEAX,0jenoPatchedMOVEAX,DWORDPTRDS:[ESI+0x77C]MOVJohn.oldA,EAXMOVEAX,John.AMOVDWORDPTRDS:[ESI+0x77C],EAXJMPfinishnoPatched:PUSHEDXM

@mock课中的模拟字段

由于我是Mockito的新手@Mock.例子:@RunWith(MockitoJUnitRunner.class)publicclasssomeServiceTest{@InjectMocksprivateMainServicemainService;@MockprivateHelpServicehelpService;@MockprivateSecondHelpServicesecondHelpService;现在有这个helpService类,其中包含一种用于测试的方法MainService.@Service@Transactional(propagation=Propagation.SU

c++ - 谷歌模拟 : Is it ok to use global mock objects?

在所有关于gmock的文档中,我总是发现要在测试中实例化模拟对象,就像这样:TEST(Bim,Bam){MyMockClassmyMockObj;EXPECT_CALL(MyMockObj,foo(_));...}因此,对象在每次测试时都会被创建和销毁。我相信为每个测试夹具创建和销毁对象也完全没问题。但我想知道是否也可以拥有模拟对象的文件全局实例,就像这样:MyMockClassmyMockObj;TEST(Bim,Bam){EXPECT_CALL(MyMockObj,foo(_))...}我试过了,到目前为止我完全没有问题,一切似乎都很好。但也许我应该知道什么?只是因为我偶然发现了t

c++ - NiceMock 一个将另一个 Mock 作为构造函数参数的 Mock

我想将Mock与NiceMock结合使用。Mock有一个构造函数,该构造函数将另一个Mock作为参数。这是我拥有的有效代码的一个小示例classClassA{ClassA(){}};templateclassClassB>{ClassB(ClassA&a){}//constructor,nodefaultconstructorforthisclass};classClassC{ClassC(){}};classMyTest:publicTest{MockClassAa;MockClassB*b=NULL;SetUp(){b=newMockClassB(a);}...};这很好用,但是如

c++ - 为什么 GCC 不允许我创建 `inline static std::stringstream` ?

我会直接去MCVE:#includestructA{inlinestaticstd::stringstreamss;};海湾合作委员会7.2和7.1refusetocompile它有以下错误:error:nomatchingfunctionforcallto'std::__cxx11::basic_stringstream::basic_stringstream()'inlinestaticstd::stringstreamss;^~Infileincludedfromblah:1:0:/opt/compiler-explorer/gcc-7.2.0/include/c++/7.2.0

c++ - CUnit - 'Mocking' libc 函数

我正在使用CUnit进行项目单元测试。我需要测试我是否使用正确的参数调用libc函数以及我是否以正确的方式处理它们的返回值。例如:如果我调用bind(...)函数-我想检查我传递了哪个af参数并断言如果这是错误的,我还想模拟它的返回值并断言如果我检查它正确的方法。出于这些目的,我希望CUnit环境有一个内置机制,让我在测试时调用“模拟”bind()函数,在运行代码时调用真正的bind()函数——但我不能找到这样的东西。如果我遗漏了CUnit中的某些内容,您能否告诉我,或者建议一种实现方法。谢谢,乔。 最佳答案 不幸的是,您不能使用C