草庐IT

builtin_constant_p

全部标签

c++ - 为什么我们需要两个定义: integral constant expression and converted constant expression?

C++14中的§5.19/3定义了一个整型常量表达式和一个转换后的常量表达式:Anintegralconstantexpressionisanexpressionofintegralorunscopedenumerationtype,implicitlyconvertedtoaprvalue,wheretheconvertedexpressionisacoreconstantexpression.[Note:Suchexpressionsmaybeusedasarraybounds(8.3.4,5.3.4),asbit-fieldlengths(9.6),asenumeratorini

c++ - 为什么我们需要两个定义: integral constant expression and converted constant expression?

C++14中的§5.19/3定义了一个整型常量表达式和一个转换后的常量表达式:Anintegralconstantexpressionisanexpressionofintegralorunscopedenumerationtype,implicitlyconvertedtoaprvalue,wheretheconvertedexpressionisacoreconstantexpression.[Note:Suchexpressionsmaybeusedasarraybounds(8.3.4,5.3.4),asbit-fieldlengths(9.6),asenumeratorini

c++ - __builtin_ctz(0) 或 __builtin_clz(0) 的未定义程度如何?

背景长期以来,gcchasbeenproviding许多内置的位旋转函数,特别是尾随和前导0位的数量(也适用于longunsigned和longlongunsigned,它们有后缀l和ll):—Built-inFunction:int__builtin_clz(unsignedintx)Returnsthenumberofleading0-bitsinx,startingatthemostsignificantbitposition.Ifxis0,theresultisundefined.—Built-inFunction:int__builtin_ctz(unsignedintx)R

c++ - __builtin_ctz(0) 或 __builtin_clz(0) 的未定义程度如何?

背景长期以来,gcchasbeenproviding许多内置的位旋转函数,特别是尾随和前导0位的数量(也适用于longunsigned和longlongunsigned,它们有后缀l和ll):—Built-inFunction:int__builtin_clz(unsignedintx)Returnsthenumberofleading0-bitsinx,startingatthemostsignificantbitposition.Ifxis0,theresultisundefined.—Built-inFunction:int__builtin_ctz(unsignedintx)R

c++ - GCC 的 __builtin_expect 能走多远?

在回答另一个问题时,我对此感到好奇。我很清楚if(__builtin_expect(!!a,0)){//notlikely}else{//quitelikely}将通过向处理器提示/更改汇编代码顺序/某种魔法来使“很可能”分支更快(通常)。(如果有人能澄清那也很棒的魔法)。但这是否适用于a)内联ifs、b)变量和c)0和1以外的值?即会__builtin_expect(!!a,0)?/*unlikely*/:/*likely*/;或intx=__builtin_expect(t/10,7);if(x==7){//likely}else{//unlikely}或if(__builtin_

c++ - GCC 的 __builtin_expect 能走多远?

在回答另一个问题时,我对此感到好奇。我很清楚if(__builtin_expect(!!a,0)){//notlikely}else{//quitelikely}将通过向处理器提示/更改汇编代码顺序/某种魔法来使“很可能”分支更快(通常)。(如果有人能澄清那也很棒的魔法)。但这是否适用于a)内联ifs、b)变量和c)0和1以外的值?即会__builtin_expect(!!a,0)?/*unlikely*/:/*likely*/;或intx=__builtin_expect(t/10,7);if(x==7){//likely}else{//unlikely}或if(__builtin_

C++ 警告 : deprecated conversion from string constant to ‘char*’ [-Wwrite-strings]

我正在使用gnuplot在C++中绘制图形。该图正在按预期绘制,但在编译期间出现警告。警告是什么意思?warning:deprecatedconversionfromstringconstantto‘char*’[-Wwrite-strings]这是我正在使用的功能:voidplotgraph(doublexvals[],doubleyvals[],intNUM_POINTS){char*commandsForGnuplot[]={"settitle\"ProbabilityGraph\"","plot'data.temp'withlines"};FILE*temp=fopen("da

C++ 警告 : deprecated conversion from string constant to ‘char*’ [-Wwrite-strings]

我正在使用gnuplot在C++中绘制图形。该图正在按预期绘制,但在编译期间出现警告。警告是什么意思?warning:deprecatedconversionfromstringconstantto‘char*’[-Wwrite-strings]这是我正在使用的功能:voidplotgraph(doublexvals[],doubleyvals[],intNUM_POINTS){char*commandsForGnuplot[]={"settitle\"ProbabilityGraph\"","plot'data.temp'withlines"};FILE*temp=fopen("da

c++ - 模拟 GCC 的 __builtin_unreachable?

我收到了很多关于开关的警告,这些警告仅部分覆盖了切换的枚举范围。因此,我想为所有这些开关设置一个“默认值”,并在这种情况下放置__builtin_unreachable(GCC内置),以便编译器知道这种情况是不可达的。但是,我知道GCC4.3还不支持该内置函数。有什么好方法可以模拟该功能吗?我考虑过取消引用空指针,但这可能会产生其他不良影响/警告等。你有更好的主意吗? 最佳答案 您可以调用声明为_Noreturn的内联函数,以将该调用之后的任何内容标记为无法访问。允许编译器在这样的函数之后抛出任何代码。如果函数本身是static(并

c++ - 模拟 GCC 的 __builtin_unreachable?

我收到了很多关于开关的警告,这些警告仅部分覆盖了切换的枚举范围。因此,我想为所有这些开关设置一个“默认值”,并在这种情况下放置__builtin_unreachable(GCC内置),以便编译器知道这种情况是不可达的。但是,我知道GCC4.3还不支持该内置函数。有什么好方法可以模拟该功能吗?我考虑过取消引用空指针,但这可能会产生其他不良影响/警告等。你有更好的主意吗? 最佳答案 您可以调用声明为_Noreturn的内联函数,以将该调用之后的任何内容标记为无法访问。允许编译器在这样的函数之后抛出任何代码。如果函数本身是static(并