草庐IT

CLANG_ARGS

全部标签

c++ - 神秘的链接器错误 "undefined reference to ` __gxx_personality_v 0'"在 cygwin 中使用 clang

我做了一些搜索,所有答案似乎都建议使用clang++而不是clang(或者更确切地说是g++代替gcc),这就是我最初所做的。尽管如此,问题仍然存在,无论是clang++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp或clang++-lstdc++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp编译和链接在Cygwin中使用g++工作正常。g++-Wall-std=c++11-otest.exetest.cppA.cppB.cppetc.cpp更新:这是链接期间的信息。clang是

c++ - 按值捕获异常 - gcc 和 clang 不同意

考虑这个简短的片段:structB{B()=default;explicitB(Bconst&){}};structD:B{};intmain(){try{throwD{};}catch(B){}}gcc接受这段代码,clang认为它格式错误:main.cpp:17:13:error:nomatchingconstructorforinitializationof'B'catch(B){^谁是对的? 最佳答案 我认为这是一个gcc错误(由于还没有人否决这个答案,我将其提交为70375)。两个编译器都正确地同意应该捕获D{},根据[e

c++ - Clang 无法在模板类特化中编译模板函数,该函数具有来自模板声明的*不同的返回类型*

以下函数derefItemX()在GCC4.8-5.3上编译正常,但在CLang3.8上编译失败://!AccessoryOperations-templateargumentdependedwrapperstemplate//ForNodes/non-scopedstoragestructOperations{//!\briefDefererencewrappedordirectiterator//!//!\paramielIItemXT&-iteratortobedereferenced//!\returnItemT&-resultingreferencetemplateconst

c++ - Clang 提示未评估的上下文中未定义的 constexpr 函数

我正在使用一个简单的SFINAE技巧来检查成员函数是否存在,如下所示:#includetemplatestructhas_size{templatestaticconstexprautocheck(T*)->decltype(std::declval().size(),std::true_type{});templatestaticconstexprautocheck(...)->std::false_type;staticconstexprboolvalue=decltype(check(nullptr))::value;};//Usage:static_assert(has_siz

c++ - 在使用 Clang 编译 CRTP Singleton 时,如何解决声称缺少 "explicit instantiation declaration"的问题?

我们正在使用curiouslyrecurringtemplatepattern实现单例。但是,在最近的Clang版本中,我们收到了-Wundefined-var-template警告。建议的修复方法是添加“显式实例化声明”。我试图这样做,但后来在定义单例模板类成员变量的编译单元中出现有关“实例化后的显式特化”的错误。解决此警告突出显示的问题的适当构造是什么?简化详细信息(已删除大部分逻辑,以制作MCVE):单例基础.hh:templateclassSingletonBase{public:staticT*get_instance(){if(!instance_){instance_=T

c++模板递归双链表错误gcc(但clang++接受)

此示例代码:#include#includetemplatestructWrapper{staticconststd::string_str;typedefconstWrapperNextType_t;//templaterecursionstaticNextType_t_nxt;typedefconstWrapperPrevType_t;//templaterecursionstaticPrevType_t_prev;};templateconststd::stringWrapper::_str=std::to_string(i);templatetypenameWrapper::N

c++ - 如何在 clang::VarDecl 中获取变量名的位置

我正在使用clang3.0库对C/C++代码进行一些分析,我需要获取变量声明的位置,我试过这段代码:clang::VarDecl*vd=...;clang::SourceManager&srcMgr=...;clang::SourceRangeloc=vd->getSourceRange();clang::PresumedLoclocStart=srcMgr.getPresumedLoc(loc.getBegin());clang::PresumedLoclocEnd=srcMgr.getPresumedLoc(loc.getEnd());但是locStart和locEnd指向声明变量

c++ - 使用 CMake 查找使用 CLang 编译的 Boost

我已经使用rubenvb在Windows上编译了Boost1.51.0|的CLang构建。我实际上使用MinGW编译了b2:bootstrapmingw...compilingb2usingmingw...然后我用CLang编译了这些库:b2toolset=clangstage--stagedir=.--build-type=complete--with-regex...顺便说一句,即使我指定了--build-type=completelib目录中也没有DLL,但我在某处读到CLang在Windows上的链接仍然存在问题,所以这可能是原因。无论如何,静态库对我来说很好。我在%BOOST

c++ - 尽管包含 <typeinfo> ,但 Clang 拒绝 type_info 为不完整

我不明白为什么Clang会拒绝以下代码:#include#includeconstchar*get_name(conststd::exception_ptreptr){returneptr.__cxa_exception_type()->name();}intmain(){}GCC没问题,但是Clang提示type_info是一个不完整的类型:$g++-4.7-std=c++0x-O3-Wall-Wextrat.cc-ot$clang++-3.2-std=c++0x-O3-Wall-Wextrat.cc-ott.cc:6:37:error:memberaccessintoincompl

c++ - GCC 4.9 和 clang 3.5 中的 std::rbegin 和 std::rend 函数

我一直在MSVC2013中使用std::rbegin和std::rend。当我尝试使用GCC4.9.1或clang3.5.0编译我的代码时,两者都告诉我“rbegin”和“rend”是不是命名空间“std”的一部分。请参阅下面的代码示例。我是在做错什么,还是只是尚未在GCC和clang中实现?//test.cpp#include#include#includeintmain(int,char**){std::vectortest={1,2,3,4,5};for(autoit=std::rbegin(test);it!=std::rend(test);++it){std::cout海湾合