草庐IT

clang-extensions

全部标签

c++ - gcc 与 clang : inlining a function with -fPIC

考虑这段代码://foo.cxxintlast;intnext(){return++last;}intindex(intscale){returnnext()使用gcc7.2编译时:$g++-std=c++11-O3-fPIC这发出:next():movqlast@GOTPCREL(%rip),%rdxmovl(%rdx),%eaxaddl$1,%eaxmovl%eax,(%rdx)retindex(int):pushq%rbxmovl%edi,%ebxcallnext()@PLT##next()notinlined,callthroughPLTmovl%ebx,%ecxsall%cl

c++ - 使用 stdlibc++ 4.7 启用 C++11 时,出现 clang 错误,而 gcc 编译正常

我一直在努力让C++11工作,在浏览了不同的网站和Q/A之后,我仍然遇到了问题。我想将clang与libstdc++一起使用。在clang状态中表明它受补丁支持-http://clang.llvm.org/libstdc++4.7-clang11.patch.我从macports下载gcc4.7并在gcc4.7的header中进行了相应的更改我不使用libc++的原因是因为libc++和libstdc++之间的ABI兼容性,此线程表明:Whycan'tclangwithlibc++inc++0xmodelinkthisboost::program_optionsexample?好的,一

c++ - 共享内存中的 boost::lockfree::queue 出现问题(boost 1.53、gcc 4.7.2/clang 3.0-6ubuntu3)

我在放置boost::lockfree::queue,..>时遇到问题在共享内存中。我需要它,因为我必须能够将超过65535条消息插入队列,而fixed_sized队列限制为65535。以下代码工作正常(但capacity选项暗示fixed_sized):typedefboost::interprocess::allocatorShmemAllocator;typedefboost::lockfree::queue,boost::lockfree::allocator>Queue;m_segment=newboost::interprocess::managed_shared_memo

c++ - 使用 Clang AST 打印函数的参数

我想获取传递给函数的参数。例如,如果我接到电话printf("%d%d",i,j);输出应该是%d%dij我能够在RecursiveASTVisitor中使用VisitCallExpr()进行函数调用。还能够获取参数的数量和参数类型。但我不知道如何获取参数。boolMyRecursiveASTVisitor::VisitCallExpr(clang::CallExpr*E){for(inti=0,j=E->getNumArgs();igetArg(i)->getType().getAsString()输出:argType:char*argType:intargType:int请帮我获取

c++ - 什么预定义宏可用于检测带有 clang 的调试版本?

MSVC在Debug模式下定义_DEBUG,gcc在Release模式下定义NDEBUG。我可以在clang中使用什么宏来检测代码是否正在为发布或调试编译? 最佳答案 如果您查看IDE的项目设置,您会发现那些宏实际上是在那里手动定义的,它们不是由编译器自动定义的。事实上,编译器无法真正知道它是在构建“调试”还是“发布”,它只是根据用户(或IDE)提供给它的标志进行构建。您必须制作自己的宏并手动定义它们,就像IDE在创建项目时为您所做的那样。 关于c++-什么预定义宏可用于检测带有clan

c++ - 在可见性有限的 `std::terminate` 函数中调用 `noexcept` - gcc vs clang codegen

考虑以下代码片段:voidf();voida(){f();}voidb()noexcept{f();}在上面的场景中,f的主体对于当前翻译单元中的编译器是不可见的。因此,由于b被标记为noexcept,必须在调用方生成额外的代码以确保异常被捕获并且std::terminate被调用。这就是clang++-Ofast-std=c++2a所做的(主干版本):a():#@a()jmpf()#TAILCALLb():#@b()pushraxcallf()popraxretmovrdi,raxcall__clang_call_terminate__clang_call_terminate:#@_

c++ - Clang 与 GCC - Variadic 模板参数包后跟具有默认值的参数在 GCC 4.8 中有效,但在 Clang 3.5 中无效

下面的代码适用于gcc-4.8.2#includeusingnamespacestd;templatevoidfunc(Args...args,intoptional=0){cout(3.3f);//Fine,prints'0'func();//gccOK,failstocompilewithclang-3.5}它输出:$./a.out1200但是如果用clang-3.5编译失败,test_variadic.cpp:15:2:error:nomatchingfunctionforcallto'func'func();^~~~test_variadic.cpp:5:6:note:cand

c++ - GCC/CLang 不同意模板模板参数的部分特化

GCC和clang不同意此代码。#includetemplatetypenameTpl>structstorage{usingtype_t=T;templateusingstorage_tpl=Tpl;};templatetypename>structF{constexprstaticintx=1;};templatestructF{constexprstaticintx=2;};intf(){usingS=storage;static_assert(F().x==2);returnF().x;}根据clangS::storage_tpl不是std::void_t;结果它选择了主模板F

c++ - clang 3.4 C++14 支持

我正在使用travis.ci对我的git存储库进行自动化测试构建。对于Linux,他们使用:Ubuntu12.04使用clang3.4根据clangpageClang3.4支持所有C++14语言功能(只要您使用-std=c++1y标志)。到目前为止一切顺利:我还需要使用std::index_sequence这是图书馆的特色N3658不是语言功能。但是我找不到任何关于为clang更新C++标准库以确保支持此功能的特定文档(不支持开箱即用)。测试代码:#includeintmain(){std::index_sequenceseq;}测试构建:>clang++-std=c++1ypl.cp

c++ - 为什么 gcc 允许 const 对象没有用户声明的默认构造函数但不允许 clang?

最近Whydoesaconstobjectrequiresauser-provideddefaultconstructor?被标记为WhydoesC++requireauser-provideddefaultconstructortodefault-constructaconstobject?的拷贝.我正在使用coliru和rextexter测试不同版本的gcc(g++-4.7、g++-4.8、g++-4.9)和clang(3.4和3.5),看看新版本的编译器是否引入了这种行为。这里我们有两个测试用例,分别来自两个问题:classA{public:voidf(){}};intmain(