草庐IT

c++ - 用于 gcc 或 clang 的 LTO 是否可以跨 C 和 C++ 方法进行优化

如果链接时优化(LTO)与gcc一起使用或clang,是否可以跨C和C++语言边界优化代码?例如,C函数是否可以内联到C++调用程序中? 最佳答案 是的!链接时优化通常适用于“胖”目标文件中存在的中间表示(IR),它可以包含用于传统链接的机器代码和用于LTO链接的IR。在此阶段,不再有高级语言结构,因此链接时优化与语言无关。海合会海湾合作委员会的link-timeoptimization(LTO)在GIMPLE上工作,GIMPLE是GCC的中间表示之一。IR始终与语言无关,因此任何链接时优化都适用于从任何语言生成的代码。来自GCCO

c++ - 函数指针的模板参数推导(g++ & ICC vs Clang++ & VC++)

考虑以下程序:#includetemplatevoidfoo(constT*x){x();}voidbar(){std::cout它在clang++和VC++上编译良好,但g++给出以下编译器错误(参见现场演示here)main.cpp:Infunction'intmain()':main.cpp:10:9:error:nomatchingfunctionforcallto'foo(void(&)())'foo(bar);^main.cpp:3:6:note:candidate:templatevoidfoo(constT*)voidfoo(constT*x){^~~main.cpp:

c++ - std::chrono::duration 的运算符/和带有 clang 的自定义类型

考虑一个自定义类型,它用于乘除持续时间的特定实例:#include#includeclassFoo{};usingDuration=std::chrono::seconds;inlineDurationoperator*(Durationd,Foo){std::cout此代码使用gcc编译时没有警告,但使用clang(wandbox)时失败Infileincludedfromprog.cc:1:/opt/wandbox/clang-7.0.0/include/c++/v1/chrono:1259:81:error:notypenamed'type'in'std::__1::common

c++ - 我如何告诉 clang-format 缩进可见性修饰符?

我希望我的可见性修饰符(public、protected和private)由当前保留它们的clang-format缩进级别作为类声明。我在默认格式选项的转储中查找了indent和visibility,但找不到任何内容。 最佳答案 来自Clang-FormatStyleOptionsdocumentation:AccessModifierOffset(int)Theextraindentoroutdentofaccessmodifiers,e.g.public:.因此,将适当的条目添加到您的.clang-format。例如,Acces

c++ - 为什么 Clang++ 编译器无法编译以下可变参数模板代码?

#include#include#include#includetemplatestructtest{usingargs_type=std::tuple;args_typex;templatevoidcallme(std::index_sequence){int_[]={(std::get(x).std::tuple_element::type::~type(),true)...};}};intmain(){}错误信息是clang-3.7-std=gnu++1y-Wc++14-extensionstest.cpptest.cpp:15:56:error:expected')'int_[

c++ - 使用 Google Test、Clang 和 libc++ 构建测试时遇到问题

我尝试使用以下CMake配置构建GoogleTest:$CMAKE_CXX_COMPILER="clang++"CMAKE_CXX_FLAGS="-std=c++11-stdlib=libc++-U__STRICT_ANSI__"cmake../sourceBuilding显示CMake选择了正确的编译器,但我的编译器标志没有通过:$VERBOSE=1make.../Users/jfreeman/local/bin/clang++-I/Users/jfreeman/work/googletest/source/include-I/Users/jfreeman/work/googlete

c++ - std::atomic<X>::value_type 发生了什么?

根据thisreferencemanualForeverystd::atomic(whetherornotspecialized),std::atomic::value_typeisX.但是如果我尝试使用这种类型,我会得到一个编译错误。我用g++8.2.1试过了:$g++-std=c++11test.cctest.cc:Infunction‘intmain()’:test.cc:6:23:error:‘value_type’isnotamemberof‘std::atomic’std::atomic::value_typex=0;还有clang6.0.1$clang-std=c++11

c++ - 如何使用 stdlibc++ 为 OS X 64b 平台编译 boost?

我想使用stdlibc++为MacOSX10.9编译boost。我运行以下命令:./b2threading=multilink=staticruntime-link=staticcxxflags="-stdlib=libstdc++"linkflags="-stdlib=libstdc++"构建成功完成;但是,我的应用程序构建在链接时失败,因为它找不到像std::__1::locale::use_facet、std::__1::basic_string等那样糟糕的符号。我相信相关的细节是__1。我的问题是,如何使用stdlibc++为OSX64b平台编译boost?更多信息:我在编译过

c++ - 右值 Hello World 缺少构造函数

我试图了解更多关于右值引用的信息,但我被困在这个最简单的例子上:#includeusingnamespacestd;structC{C(){cout我用Clang3.2和-std=c++11-fno-elide-constructors编译了它(以避免(N)RVO)但结果令我惊讶:C()~C()//huh?C(C&&)~C()~C()除了第一个~C()之外,我完全符合预期。它是从哪里来的,我错过了什么,因为有2个构造和3个破坏?&&构造函数是否使用已销毁的对象引用调用?? 最佳答案 这一定是个错误。foo()中构造的本地对象的析构函

c++ - 如何从 std::basic_ios 为 OS X 上的 clang 获取文件描述符?

我正在将一些代码移植到DarwinOSX,作为更改的一部分,我们从gcc转到clang编译器。代码中有一个2005年的函数,在网上多处贴过。它为几个不同的旧版本GCC提供了功能,我已经编辑了除最后一个版本之外的所有功能,v3.4.0或更高版本。该代码取决于两个GCC特定类:__gnu_cxx::stdio_filebuf和__gnu_cxx::stdio_sync_filebuf。//!Similartofileno(3),buttakingaC++streamasargumentinsteadofa//!FILE*.Notethatthereisnowayforthelibraryt