jjzjj

backtrack_inline

全部标签

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

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++ `inline` 关键字和编译器优化

我一直听说inline关键字不再用作现代编译器的提示,而是用于避免多源项目中的多重定义错误。但是今天遇到了编译器服从关键字的例子。没有inline关键字,如下代码#includeusingnamespacestd;voidfunc(constintx){if(x>3)cout使用命令g++-O3-Sa.cpp,生成func未内联的汇编代码。但是,如果我在func的定义前添加inline关键字,func将被内联到main中。生成的汇编代码部分为.LC0:.string"HAHA\n".LC1:.string"KKK\n".text.p2align4,,15.globl_Z4funci.t

现在允许对ConstexPR静态数据成员的重新定义? (但不是Inline Const)?

以下未能在C++14中的GCC和Clang下进行编译,但C++1Z成功:structCls{staticconstexprintN=0;};constexprintCls::N;constexprintCls::N;C++14错误是可以预见的:redefinitionof‘constexprconstintCls::N’是什么改变了这一合法?我发现:N465910.1.5[DCL.Constexpr]使用ConstexPR规范声明的函数或静态数据成员隐含是内联函数或变量所以我认为这可能与内联变量有关,但是两个编译器下的C++1Z失败structCls{staticinlineconstintN

c++ - 为什么 MSVC 10.0 编译器经常忽略 inline 关键字?

我有一些非常复杂的c++代码,用于实时系统,因此对速度绝对敏感。它是在Linux上开发的,为了加快它的速度,许多函数都标有“内联”关键字,并移至头文件中以允许内联。现在我将此代码移植到Windows(msvc10.0、Windows7),它的运行速度大约慢了30%。在做了一些分析之后,我发现问题基本上是很多函数没有内联。当我改用“__forceinline”时,我很容易看到速度提高了10-20%。有人对此有解释吗?仅仅是因为msvc中的算法更加保守吗?还是我只是做错了什么,比如缺少配置选项? 最佳答案 您需要检查您的MSVC优化设置

c++ - 编译器是否更有可能使用指定的 inline 关键字在类声明中内联函数?

我最近在查看一位同事的代码,注意到他在类声明中定义的一堆Getter函数前面放置了“inline”关键字。例如classFoo{public:inlineboolGetBar()const{returnm_Bar;}private:boolm_Bar;};我在代码审查中建议他删除内联关键字,正如我在许多不同的地方读到的那样,在类声明中定义函数是由编译器解释的(在这种情况下为MSVC,但显然是C++标准的一部分)作为作者想要内联函数的指示。我的感觉是,如果额外的文本没有任何作用,那只是不必要的困惑,应该删除。他的回应如下:inline关键字让与此代码交互的其他程序员清楚地知道这些函数是/

c++ - C/C++ : How does this inline if get parsed?

考虑这段代码:intmain(){cout它的输出将是1,而不是Yes或No。为什么将true发送到输出流而不是Yes或No字符串?内联if的其余部分如何解析? 最佳答案 这与操作顺序有关。这与:(coutcout返回ostream&,它必须转换为bool或等价物。?:的结果被扔掉了。如果这看起来很奇怪(为什么这个优先级?),请记住ostream的operator是C++代码中引入的重载,它不允许更改优先级。的优先级专为对移位有意义的内容而设计。它作为流媒体运营商的使用要晚得多。编辑:可能转换为(void*)使用这个:http://

C++ _inline 在单例中被忽略并出现在我的探查器中。怎么会?

我的项目中有很多类被单例访问,如下所示:_inlineGUI_BS_Map*GUI_GetBS_Map(){staticGUI_BS_Mapobj;return&obj;};据我了解,这段代码应该是内联的。我将VisualStudio(2005)选项设置为内联任何合适的内容,并且我的探查器(AQTime)绝对没有设置为覆盖_inlines。但是,当我分析代码时,它们对我的每个单例函数进行了数千次调用。我可能会错过什么?(我正在分析调试版本(以获取分析器的符号)但所有速度优化都已打开。)非常感谢任何建议! 最佳答案 编译器可以随意忽略

c++ - 为什么不允许 "inlined"静态常量,整数除外?

PossibleDuplicateWhycan'tIhaveanon-integralstaticconstmemberinaclass?structExample{staticconstintOne=1000;//LegalstaticconstshortTwo=2000;//IllegalstaticconstfloatThree=2000.0f;//IllegalstaticconstdoubleFour=3000.0;//IllegalstaticconststringFive="Hello";//Illegal};#2、#3、#4和#5是非法的吗?我想我知道#5的原因:编译器