草庐IT

clang_complete

全部标签

c++ - Clang 声称通用 lambda 参数的 constexpr 成员不是 constexpr

我想编写一个通用的lambda作为变体的访问者。这个变体的成员包含一个constexpr成员值,我想在访问者中使用它。例如:#includetemplatestructS{constexprstaticintthis_r=r;};intf(std::variant,S,S>v){returnstd::visit([](autoconst&arg){ifconstexpr(arg.this_r==0){return42;}else{returnarg.this_r;}},v);}intg(){std::variant,S,S>x=S();returnf(x);}GCC乐于从大约versi

Code Complete 关于封装的 C++ 建议?

CodeComplete中关于“良好封装”的部分,建议隐藏私有(private)实现细节。C++中给出了一个例子。这个想法基本上是将接口(interface)与实现完全分离,即使在类级别也是如此。classEmployee{public:...Employee(...);...FullNameGetName()const;StringGetAddress()const;private:EmployeeImplementation*m_implementation;};这样真的可以很好地利用时间吗?这不仅看起来效率低下(这会带来什么样的性能损失?),而且CodeComplete的整个座右

c++ - 强制 Clang 链接到 C++ 运行时

我有一个包含C和C++源代码混合的项目。它目前在OSX上使用GCC构建。该项目有定制的构建脚本,调用gcc命令来编译C和C++源代码,并单独调用链接器。我现在正尝试使用Clang构建它。调用clang会正确编译源文件;它区分.c和.cpp源文件,并针对每种情况编译适当的语言。不过,我在链接时遇到了问题。当链接器作为clang调用时,C++运行时库未链接进来,导致由于缺少符号而导致构建错误。当我将clang++设置为构建工具时,我可以成功链接,但这会导致编译时错误和警告;它真的不喜欢用C++编译器编译C源代码。clang:warning:treating'c'inputas'c++'wh

c++ - 为什么代码被clang接受而被vc++拒绝?

clang3.4接受以下代码;而vc++NOV2013CTP拒绝它并出现错误:errorC2668:'AreEqual':ambiguouscalltooverloadedfunctiontemplateconstexprheadT&&__GetFirst__(headT&&value,tailTypes&&...){returnstatic_cast(value);};templateconstexprboolAreEqual(constT&a,constT&b){returna==b;}templateconstexprboolAreEqual(constheadT&head_va

c++ - gcc 和 clang 都省略了下面代码段中对移动构造函数的调用。这个对吗?

在下面的代码中,类S的对象s用于通过直接初始化来初始化类D的对象>Dd(s);。转换函数S::operatorD()用于将对象s转换为D类型的临时对象。然后,gcc和clang都省略了对移动构造函数D(&&)的显式调用,以将此临时对象移动到d中。参见liveexample.#includestructD;structS{operatorD();};structD{D(){}D(D&&){std::cout我基于以下理由质疑这种省略的正确性:这种情况包含在§8.5/16(N3337)的第一个子项目符号点中,其中没有提及省略。Iftheinitializationisdirect-init

c++ - 在 GCC、Clang 和 MSVC 中,有什么方法可以符合 C++98 而不是 C++03 吗?

metaquestion建议c++98和c++03标签应该是同义词。提问者跟进了IsvalueinitializationpartoftheC++98standard?Ifnot,whywasitaddedintheC++03standard?,一个很好的问题,它阐明了向C++03添加值初始化。将此问题视为后者的后续问题。OP断言现代编译器不会费心区分C++98和C++03。这让我感到惊讶,因为事实证明是三个现代编译器的情况。虽然这个问题可以归结为“RTFM”,但我的搜索没有找到任何结论。海湾合作委员会他们的standards页:TheoriginalISOC++standardwas

c++ - 哪个 Clang 警告等同于 GCC 的 Wzero-as-null-pointer-constant?

我们的项目使用C++11/14,我们希望使用nullptr而不是0或NULL指针,即使0(作为整数文字)是允许的。我有以下代码:intmain(){int*ptr1=nullptr;//#1int*ptr2=0;//#2}如果我使用GCC(5.3.0)和标记-Wzero-as-null-pointer-constant进行编译,它会在#2中发出警告,但我可以'在Clang中找不到类似的标志。如果我使用Clang(3.7.1)和标志-Weverything编译代码,我不会收到任何关于#2的警告。那么,有什么办法可以在Clang中得到类似的警告吗? 最佳答案

c++ - 使用 C++11 在 Cygwin 上使用 Clang

我在Cygwin上安装了Clang并尝试编译这段代码:#includeintmain(){std::cout如果我执行clang++file.cpp,效果很好。如果我执行clang++file.cpp-std=c++11,它将不起作用。我从这样的标准header中得到错误:Infileincludedfromfile.cpp:1:Infileincludedfrom/usr/lib/gcc/i686-pc-cygwin/4.5.3/include/c++/iostream:39:Infileincludedfrom/usr/lib/gcc/i686-pc-cygwin/4.5.3/in

c++ - 不允许 clang 变量名中的 Unicode/特殊字符?

Thisquestionhasunicodetextthatmaynotdisplaycorrectlyinallbrowsers.clang现在(>3.3)在变量名中支持unicode字符http://llvm.org/releases/3.3/tools/clang/docs/ReleaseNotes.html#major-new-features.但是一些特殊字符仍然被禁止。intmain(){doubleα=2.;//alpha,ok!double∞=99999.;//infinity,error}给予:error:non-ASCIIcharactersarenotallowe

c++ - 设置 IndentWidth 在 clang 格式中不起作用

我的主目录中有.clang-format并设置indentwidth4如下。BasedOnStyle:LLVMStandard:Cpp11IndentWidth:4TabWidth:4UseTab:Never但是当我使用clang-format-style='~/.clang-format'a.cpp格式化我的代码时,缩进宽度变为2。例如://Seethisindentwidth2.Theoriginalfilehaswidth4,//butclang-formatchangesittowidth2.intmain(intargc,charconst*argv[]){Aa;a.bar(