草庐IT

Clang-Format

全部标签

c++ - Clang 无法从基类中找到 const 模板成员函数

以下C++文件:structBase{templatevoidf(T&&)const{}};structDerived:Base{templatevoidf(T&&)const{}usingBase::f;};intmain(){Derivedconstcd;cd.f('x');}用GCC编译得很好,但用Clang编译不好:$g++-7.3.0-std=c++11test.cpp-otest-Wall-Wextra$g++-7.2.0-std=c++11test.cpp-otest-Wall-Wextra$g++-6.4.0-std=c++11test.cpp-otest-Wall-W

c++ - 为什么 GCC 会为结构化绑定(bind)诊断未使用的变量而 Clang 不会?

让我们从一个最小的例子开始:#includeintmain(){auto[a,b]=std::pair(1,'A');returna;}使用GCC7.3编译传递-std=c++17和-Wunused-variable,并运行它::Infunction'intmain()'::5:15:warning:unusedvariable'b'[-Wunused-variable]auto[a,b]=std::pair(1,'A');^GCC可能会正确地报告未使用b,但它错误地将其称为变量。引用[dcl.struct.bind]/1:Astructuredbindingdeclarationin

c++ - 带有 libc++ 异常的 Clang

我一直在试验不同的C++库,并发现了以下内容:简单的应用:#includeintmain(intargc,char*argv[]){try{throw1;}catch(...){std::cout当我像这样在ARM上编译它时:clang++-stdlib=stdlibc++如预期的那样捕获了异常。但是当我把它改成:clang++-stdlib=libc++我不断得到:terminatingwithuncaughtexceptionoftypeintAborted我尝试使用各种标志显式打开异常,例如:-fexceptions-fcxx-exceptions-frtti但是这些标志都不起作

c++ - 编写 c++ 函数 format_string 进行格式化,如 std::string 的 sprintf

为了方便使用,我想编写类似于sprintf的格式化函数,只返回std::string,如下所示:std::stringformat_string(constchar*format,...)我可以在那里使用vsnprintf但有问题-我事先不知道临时缓冲区应该有多长。Microsoft上有函数_vscprintf可以做到这一点,但我认为它不可移植?一个选项是让临时缓冲区开始一些已知的大小,然后如果发现它不够用vsnprintf增加它。有更好的方法吗?谢谢附言请在没有提升的情况下给出答案。我知道Boost,但我很好奇如何在没有Boost的情况下实现它。 最佳答案

c++ - Clang VS VC++ :"error: declaration of ' T'阴影模板参数”

我正在尝试为theclassiccopy&swapidiom编译以下代码在我的Mac上使用clang3.3templateclassnode{private:node*left;node*right;Tvalue;public:friendvoidswap(node&,node&);//otherstuff}然而链接器却报错了。我现在明白我应该将函数声明为模板。但是,如果我按照建议的样式进行操作,则会发生错误here来自MSDN:templateclassArray{T*array;intsize;public:template//...templatefriendArray*comb

c++ - Clang 无法再使用 <functional> header 编译程序

我在运行ArchLinux的系统上使用clang版本4.0.0,它一直运行良好,但最近我无法再编译使用某些STLheader的程序了!详细信息:clang--version的输出:clangversion4.0.0(tags/RELEASE_400/final)Target:x86_64-unknown-linux-gnuThreadmodel:posixInstalledDir:/usr/bingcc--version的输出:gcc(GCC)7.1.120170528示例:我尝试编译以下简单程序:#includeintmain(){return0;}我正在使用以下命令:clang++

c++ - 模板模板参数在 Clang 但不是 GCC 下导致编译器错误

这个问题在这里已经有了答案:Templatetemplateparameteranddefaultvalues[duplicate](1个回答)关闭4年前。同时帮助解决toomanytemplateparametersintemplatetemplateargument中提到的问题我脑子里出现了一个问题:在这种情况下,哪个编译器是正确的编译:templateclassOp>classFunction{};template::value||std::is_floating_point::value>structOperator;templatestructOperator{};templ

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

c++ - Qt - 获取 "warning: format not a string literal and no format arguments"

在这样的行上不断收到警告qDebug("Anerroroccuredwhiletryingtocreatefolder"+workdir.toAscii());workdir是QString()warning:formatnotastringliteralandnoformatarguments 最佳答案 大概应该是:qDebug("Anerroroccuredwhiletryingtocreatefolder%s",workdir.constData());自qDebug将constchar*作为第一个参数。

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