草庐IT

c++ - 在 GCC 工作正常的情况下使用 Clang 时无限递归模板实例化?

以下C++代码的目的是将三元运算符(?:)包装在一个单独的函数中,稍后将有助于构建语法树。在查看真正的C++代码片段之前,让我们快速看一下它在伪代码中的作用:boolrecursive(boolv){returnv?v:recursive(v);}intmain(){boolr=recursive(true)}不幸的是,当三元运算符(?:)包含在模板函数中时,Clang会在终止递归时遇到问题:/******************DECLARATIONS******************/templateconstexprTrecursive(Tt);structIfCase{tem

c++ - C++ 中的重载 lambda 以及 clang 和 gcc 之间的区别

我正在尝试在C++中重载lambda的技巧。具体来说://Forstd::function#include//Forstd::string#include//Forstd::cout#includetemplatestructoverload:F...{overload(F...f):F(f)...{}};templateautomake_overload(F...f){returnoverload(f...);}intmain(){std::functionf=[](intx,inty){returnx+y;};std::functiong=[](doublex,doubley){r

c++ - clang 和 gcc 之间对三元运算符的 const 引用地址的差异

我对这里发生的事情有一个模糊的想法...它与this有关但我想知道为什么clang++和g++以不同的方式处理这个问题。这里的未定义行为在哪里?注意:这与模板无关——我只是使用它们来使示例更紧凑。这都是关于whatever的类型。#include#includetemplatevoidtest(){Twhatever='c';constchara='a';std::cout();test();return0;}gcc输出(测试到4.9.3):begin:0x7fffe504201fref:0x7fffe504201fbegin:0x7fffe504201eref:0x7fffe5042

c++ - 自引用使用 unordered_map 会导致 gcc 5.3 出现问题但不会导致 clang

以下代码无法在gcc5.3下编译(它是从较大代码段中提取的缩减版本):#include#includeclassFoo{std::unordered_mapm;//"self-referential"};intmain(){Foof;return0;}有以下错误:g++--std=c++1y-crh.cppInfileincludedfrom/usr/local/include/c++/5.3.0/utility:70:0,from/usr/local/include/c++/5.3.0/unordered_map:38,fromrh.cpp:1:/usr/local/include/

c++ - 为什么在使用 GCC 7、libstdc++ 和 -fgnu-tm 编译时,std::is_function 无法识别 transaction_safe 函数?

下面的编译失败是由于libstdc++缺陷造成的,还是此行为符合事务内存TS(n4514)?#includestatic_assert(std::is_function_v,"");intmain(){} 最佳答案 它应该可以工作,请提交一份GCC错误报告。 关于c++-为什么在使用GCC7、libstdc++和-fgnu-tm编译时,std::is_function无法识别transaction_safe函数?,我们在StackOverflow上找到一个类似的问题:

c++ - GCC 和 Clang 都不会通过编译时已知的函数指针数组进行内联调用——为什么?

CompilerExplorer上的示例代码:https://godbolt.org/g/fPfw4k我曾尝试使用函数指针数组作为跳转表而不是开关,因为我发现它更简洁。然而,令我惊讶的是,GCC和Clang编译器似乎都无法内联它。是否有具体原因?包含死链接的示例代码:namespace{templateintbar(){returnN;}intfoo1(intn){if(n5){__builtin_unreachable();}#if__clang____builtin_assume(n>=0&&n,bar,bar,bar,bar,bar};returnfns[n]();}intfoo

c++ - 使用 LLVM-gcc 或 gcc 进行部分评估/特化

我对c/c++的(部分)编译时评估很感兴趣(不像c++中那样使用模板参数)。让我们考虑以下情况(取自[1]):doublemypower(doublex,intn){inti;doubleret=x;for(i=1;i然后你在代码的某处调用这个函数:mypower(x,3);//yvariesallthetime,然后编译器可以对此进行优化(例如循环展开)。我使用的一些常用功能确实可以从该优化中受益(通过手动创建专用功能进行测试)。演示文稿[1]描述了一个过程,在该过程中搜索函数并将其替换为函数的专门版本。这似乎有效。但是好像不是很通用,需要替换的功能需要自己写代码。该演示文稿似乎是从

c++ - 这个不可复制的 map 是否合法 c++11? GCC 4.7 和 MSVS 2010 允许它。 Clang 3.1 没有

我创建了一个不可复制的map,我无法使用clang对其进行编译。由于clang非常符合标准,我想知道我的代码是否合法。MSVS2010和GCC4.7编译此代码时没有警告或错误。附上完整代码:有问题的行是main的最后一行。=delete需要删除MSVS2010#include#include#includetemplate>classnon_copyable_map:publicstd::map{typedefstd::mapBaseType;public:non_copyable_map(){}non_copyable_map(non_copyable_map&&t):BaseTyp

c++ - 命令输入文件如何影响 GCC 中的链接和静态初始化?

假设我有以下文件:lib/A.h#ifndefA_H#defineA_H#includeclassA{public:staticintadd(intx);staticintsize();private:staticstd::vectorvec;};#endiflib/A.cpp#include"A.h"std::vectorA::vec;intA::add(intx){vec.push_back(x);returnvec.size();}intA::size(){returnvec.size();}lib/B.h#ifndefB_H#defineB_HclassB{public:sta

c++ - GCC 4.7.1 具有重载的广义常量表达式问题

我尝试使用模板特化来实现编译时算法选择。我散列以下代码:templatestructchoose{typedefsize_t(*type)(constC*);staticconstexprtypevalue=java_string_hashcode;};我已将此结构专门用于char类型:templatestructchoose{typedefsize_t(*type)(constchar*);staticconstexprtypevalue=fnv_1a_32_hash;};但是当我尝试编译它时,我在GCC4.7.1中遇到以下错误:error:fieldinitializerisnot