草庐IT

forward_static_call

全部标签

c++ - GMock - 使用 ON_CALL 为重载方法返回默认值

我正在尝试为包含三个重载方法的类编写模拟,即:#include#includeusing::testing::_;using::testing::Return;using::testing::A;using::testing::ByRef;using::testing::Ref;using::testing::TypedEq;structFoo{intfooMethod(constint&intParam){return0;}intfooMethod(constfloat&floatParam){return0;}intfooMethod(conststd::string&string

c++ - 通过通用引用传递的函数的 std::forward?

考虑以下两个:templatevoidapply(Function&&function){std::forward(function)();}和templatevoidapply(Function&&function){function();}在什么情况下有区别,具体有什么区别? 最佳答案 如果Function的operator()具有ref限定符,则存在差异。使用std::forward,传播参数的值类别,没有它,值类别将丢失,函数将始终作为左值调用。LiveExample.#includestructFun{voidoperat

c++ - Qt 5.5 与 qmake : Linker cannot resolve OpenGL function calls

当使用Qt5.5、qmake和MSVC13编译带有一些基本OpenGL函数调用的基本样板Qt应用程序时,出现以下链接器错误:glwidget.obj:-1:error:LNK2019:unresolvedexternalsymbol__imp__glClear@4referencedinfunction"public:virtualvoid__thiscallGLWidget::initializeGL(void)"(?initializeGL@GLWidget@@UAEXXZ)glwidget.obj:-1:error:LNK2019:unresolvedexternalsymbol

c++ - static_cast 可以将非空指针转换为空指针吗?

我需要为回调函数编写代码(它将在ATL中调用,但这并不重要):HRESULTcallback(void*myObjectVoid){if(myObjectVoid==0){returnE_POINTER;}CMyClass*myObject=static_cast(myObjectVoid);returnmyObject->CallMethod();}这里的void*保证是指向CMyClass的指针,所以static_cast是合法的。我关心的是代码必须尽可能可移植(至少对于较新版本的VisualC++)。所以super偏执狂我也倾向于检查CMyClass*指针-我的意思是如果结果为空

c++ - 类内部和外部的 static 关键字

static关键字一般是跟内部链接有关,但是在类内部使用的static关键字是有外部链接的吧?下面的变量m、n可以在类文件之外访问。classc{inti;intj;staticintm;staticintn;public:voidzap();staticvoidclear();}; 最佳答案 没错。关键字static被严重重载,具有太多不同的含义:在命名空间范围内的变量或函数上,它给出名称内部链接。在类成员上,它使其成为静态成员,这不会影响链接。在函数范围内的变量上,它赋予变量“静态存储持续时间”,而不是“自动”或“动态”存储持续

c++ - 没有用于使用可变参数调用 std::forward(const std::string &) 的匹配函数

我正在尝试为不可复制、不可移动的类制作一个可移动的包装器,但是我在将conststd::string变量传递给构造函数时遇到问题。下面的最小示例会产生以下错误:#include#include#include#includestructX{std::stringx;X(conststd::string&x):x(x){}X(constX&x)=delete;X(X&&x)=delete;};structWrapper{std::unique_ptrx;Wrapper(constWrapper&wrapper)=delete;Wrapper(Wrapper&&wrapper)=defau

c++ - 为什么 C++ 标准要求 `Clock::now` 函数为 `static` ?

在C++11中,C++在标准中有一些计时工具。这些设施之一是时钟的标准接口(interface),它基本上允许在调用时钟的now函数时获取时间。到目前为止一切都很好,但我看不出要求now是静态函数的原因。在托管系统上,标准时钟可能可以纯粹通过系统调用或通过读取处理器计数器等来实现。但是,这限制了需要维护某些状态的自定义时钟的实现。使用此接口(interface),要么无法实现某些时钟,要么必须使用全局状态。我遇到的一个问题基本上是将本地时钟与我从NTP服务器获取的时间同步。代码看起来像这样:classsntp_clock{public:sntp_clock():local_time_a

c++ - 错误 : pure virtual method called - terminate called without an active exception - Aborted

在我的A.h文件中:classA{private:unsignedshortPC;public:A():PC(0){}virtual~A(){}virtualvoidexecute(unsignedshortPC)=0;};在我的B.h文件中:classB:publicA{private:intstatus;boolexe;public:B:status(0),exe(false){}virtualB(){}voidexecute(unsignedshortPC);};在我的B.cpp文件中:#include#include"B.h"voidB::execute(unsignedsho

c++ - 对相同(原始)类型的 static_cast 会产生任何代码吗?

我想这一切都在标题中说了...但这是一个例子。给定voidfunctionThatTakesAFloat(floatpar);floatf=3.5f;做functionThatTakesAFloat(static_cast(f));与相比产生任何额外的代码functionThatTakesAFloat(f);或者这个static_cast是否被编译器完全消除了?编辑:我正在使用VC++(2010) 最佳答案 5.2.9/-2-AnexpressionecanbeexplicitlyconvertedtoatypeTusingasta

c++ - static_cast<char*> 和 (char*) 之间的区别

这是我的第一个问题:)我有一堆文件,我打开它如下图所示;ifstreamin(filename,ios::binary|ios::in)然后,我希望在unsignedinthold中保存2个字节的数据;unsignedinthold;in.read(static_cast(&hold),2);这对我来说似乎是正确的。但是,当我用编译它时g++-ansi-pedantic-errors-Werror--Wall-omainmain.cpp编译器报错error:invalidstatic_castfromtype‘unsignedint*’totype‘char*’其实我已经通过将stat