草庐IT

this_file

全部标签

c++ - msvc 相当于 gcc 的 __BASE_FILE__

在VisualC++中是否有任何等效于__BASE_FILE__的东西?我想知道当前正在由VC++编译的文件的名称。注意:__FILE__展开为当前文件,例如它可能是#include之一。来自gcc的文档:__BASE_FILE__此宏以C字符串常量的形式扩展为主输入文件的名称。这是调用C编译器时指定为参数的源文件。 最佳答案 感谢John的评论,这是一个解决方法。如果您简单地输入__BASE_FILE__=%(Filename),它不会生成文字字符串。所以把它放在双引号之间;我还添加了扩展名,因为%(Filename)没有它。__

c++ - 为什么我不能将 this 指针显式传递给成员函数?

C++标准(ISOc++11)在第9.3.1节中提到Anon-staticmemberfunctionmaybecalledforanobjectofitsclasstype,orforanobjectofaclassderived(Clause10)fromitsclasstype,usingtheclassmemberaccesssyntax(5.2.5,13.3.1.1).尝试使用g++(版本4.8.2)编译此代码classfoo{public:voidbar(){cout给出编译时错误,因为它无法匹配函数的签名。考虑到标准关于调用成员函数的规定,我想这是意料之中的。由于该方法在

c++ - std::thread 类与 C++ 中的 std::this_thread 命名空间?

当我们已经有了一个std::thread类时,为什么我们需要std::this_thread命名空间?它们之间的基本区别是什么?什么时候应该使用std::thread类以及什么时候使用std::this_thread命名空间? 最佳答案 this_thread命名空间将访问当前线程的函数分组,所以当我们需要在当前线程上做一些事情时,我们不需要访问thread对象线程。线程类不提供对yield和sleeping的访问,这些函数只对当前线程有意义,因此可以在this_thread命名空间中找到。如果我们想要关于不同线程的信息,我们需要那

c++ - 对成员函数的模糊调用以在 lambda 中捕获 this

我在尝试为捕获的this调用lambda内部的成员函数时遇到了问题。该函数有const和非const版本,它以类型为​​模板。下面的代码演示了错误:structTEST{templatevoidtest(){}templatevoidtest()const{}TEST(){[this](){test();}();}};消息:http://rextester.com/MLU2098source_file.cpp(13):errorC2668:'TEST::test':ambiguouscalltooverloadedfunctionsource_file.cpp(7):note:coul

c++ - 你应该如何用 shared_ptr 返回 *this?

另请参阅:Similarquestion下面的代码显然是危险的。问题是:您如何跟踪对*this的引用?usingnamespaceboost;//MyClassDefinitionclassMyClass{public:shared_ptrcreateOtherClass(){returnshared_ptrOtherClass(this);//baaad}MyClass();~MyClass();};//OtherClassDefinitionclassOtherClass{public:OtherClass(const*MyClassmyClass);~OtherClass();}

解决git报错 “remote: Please remove the file from history and try again.”

使用git提交代码时报错:remote:error:File:90b39f4470e405ed852e517a73473b527ac60eaa362.16MB,exceeds100.00MB.remote:Usecommandbelowtoseethefilename:remote:gitrev-list--objects--all|grep90b39f4470e405ed852e517a73473b527ac60eaaremote:Pleaseremovethefilefromhistoryandtryagain.应该是提交的文件中有超过100MB的。解决方案:1、按照提示执行命令查看超大的

c++ - DEBUG_NEW 和 __FILE__ 有什么用?

我看到了下面的宏,#ifdef_DEBUG#definenewDEBUG_NEW#UNDEFTHIS_FILEstaticcharTHIS_FILE[]=__FILE__;#endif上述宏的用法是什么?谢谢 最佳答案 DEBUG_NEW只是一个MACRO,通常定义为:#defineDEBUG_NEWnew(__FILE__,__LINE__)#definenewDEBUG_NEW因此,无论您在哪里使用new,它都可以跟踪文件和行号,这些文件和行号可用于定位程序中的内存泄漏。而__FILE__、__LINE__都是predefine

c++ - 如何在 C++ 的构造函数中使用 __FILE__ 和 __LINE__ 作为默认参数?

我试图在构造函数中使用__FILE__和__LINE__宏作为默认参数,但我似乎无法让宏使用正确的文件.它们从我的头文件中不断扩展。更详细的说:我想要一个对象被实例化为我的类的成员的文件和行号。但我不想每次要使用这些对象时都必须手动输入参数。我知道有办法做到这一点,但我一辈子都想不出来。我目前正在做的是:在我的头文件中:mnNumber(floatx,constchar*filename=__FILE__,intlinenumber=__LINE__):value(x),mFileName(filename),mFunctionName(nullptr),mLineNumber(lin

c++ - .obj : fatal error LNK1107: invalid or corrupt file: cannot read at 0x6592

我正在尝试将.obj模型加载到我的C++opengl3代码中,但由于某种原因它给了我这个错误:1>正在链接...1>.\bunny.obj:fatalerrorLNK1107:无效或损坏的文件:无法在0x6592处读取我试图搜索类似的错误,但有关于.dll或.lib的错误。你能帮我解决这个问题吗?我也尝试过使用不同的obj模型,但它总是给我这个错误。 最佳答案 您正在尝试使用C++链接器加载您的对象模型(可能您刚刚将它添加到项目中,现在它正在尝试编译)。链接器可以处理.obj文件,但它等待它们成为“目标代码”文件(通常也有.obj扩

c++ - 为什么编译器说 : 'enable_if' cannot be used to disable this declaration

templateusingEnable_if=typenamestd::enable_if::type;classDegree;templateconstexprinlineboolIs_Degree(){returnstd::is_base_of::value;}classDegree{public:std::size_tinDeg=0;};templateclassVertex:publicSatellite{public:explicitVertex(intnum):n(num){}private:std::size_tn;};templateclassEdge{public:/