草庐IT

llvm-gcc

全部标签

c++ - 如何在 gcc 版本之间正确切换?

我想玩C++2011,所以我需要未发布的gcc4.7。我能够成功获取svn主干并编译它。为了安全起见,我想保留系统的默认gcc,因此我使用--prefix配置了gcc4.7,并将其安装在非标准位置。现在我应该如何在我系统的默认gcc上启用gcc4.7?我已经更改了CC和CXX变量,我更新了我的PATH以指向gcc4.7bin首先是目录。当我输入gcc--version时,我得到4.7OK。但是gcc不仅仅是一个可执行文件。gcc安装目录中有许多可执行文件。还有默认包含和stdlibc++。到目前为止,我发现的关于这个主题的每个博客条目/SO问题都只涉及gcc和g++可执行文件。任何人都

c++ - 我可以将英特尔的 TBB 与 gcc 一起使用吗?

我可以将intel的TBB与gcc一起使用吗?如果不是,什么是等价物,以便我可以在使用gcc编译时使用它?我不认为我可以,但问总是更好。 最佳答案 你可以,这就是他们的documentation不得不说:DoIhavetouseIntel’scompilers?No.YoushouldbeabletouseanyISOcompliantC++compiler.Wehavetesteditverywellonthegnu(gcc)compiler,Intel’sC++compiler,Microsoft’scompiler,andAp

c++ - llvm/clang 自身重新编译

在阅读了这里的许多问题后,我决定试试clang,并在Ubuntu12.04(64位)上安装了svn版本。我原以为会出现问题,但编译顺利,没有任何警告。我注意到当重新运行配置脚本时,如果clang/clang++在你的路径中,它会选择这个而不是gcc/g++来进行自己的编译。用自己重新编译llvm/clang是个好主意吗?我知道这绝对是gcc的标准,但我读到clang的C++实现还不够好(也许这是过时的信息...)。 最佳答案 Clang已经self托管了几年。失去这种能力将是一种严重的倒退。Clang目前对C++的支持相当不错。甚至

c++ - 类构造函数和对象实例化/初始化 C++/GCC

我在使用GCC的C++类构造函数方面遇到了麻烦。下面的“foo”类应该模拟处理器寄存器,如AL、AH、AX、EAX等,我需要一些与此类相关的基本算法。但我在初始化或“foo”对象中有一个奇怪的行为。对于以下两种情况,我没有相同的结果:foow=0x12345678;//case1foow;//case2init(2steps)w=0x12345678;对我来说,情况2有效GCC调用foo()(构造函数1),然后调用=运算符。最后,w.m_val没问题但是对于案例1,GCC直接调用foo(long*)(构造函数2),仅此而已。显然这不是我所期待的。如果“foo”是char、int或lon

c++ - gcc 的自动向量化消息是什么意思?

我有一些我想快速运行的代码,所以我希望我能说服gcc(g++)对我的一些内部循环进行矢量化。我的编译器标志包括-O3-msse2-ffast-math-ftree-vectorize-ftree-vectorizer-verbose=5但是gcc未能矢量化最重要的循环,给我以下并非真的非常冗长的消息:Notvectorized:complicatedaccesspattern.和Notvectorized:unsupporteduseinstmt.我的问题是(1)这些到底是什么意思?(在它太复杂之前它必须有多复杂?不支持使用什么?),以及(2)有什么方法可以让编译器给我更多关于我在做什

c++ - 将一些代码移植到 GCC,#pragma 指令有一些问题

我正在尝试使用GCC编译此代码,并且我有这些#pragma指令,我正在尝试将它们转换为GCC可理解的指令,但我不知道如何:#pragmasection(".CRT$XCA",read,write)#pragmadata_seg(".CRT$XCA")//startofctorsection_PVFV__xc_a[]={0};#pragmasection(".CRT$XCZ",read,write)#pragmadata_seg(".CRT$XCZ")//endofctorsection_PVFV__xc_z[]={0};#pragmadata_seg()#pragmacomment(l

c++ - NetBeans IDE gcc 编译器优化选项

我将NetBeans7.1与GCC4.7一起使用。我正在尝试更改当前设置为O2的默认优化选项。在项目属性中,我选择"C++Compiler"->“附加选项”并添加-O3。但是在编译时我仍然在命令行中看到GCC使用-O2。如何将它替换为-O3或任何其他选项? 最佳答案 首先,您需要为适当的编译器(c/c++)设置选项。看起来(至少Netbeans7.0.1)在优化开关之前添加了额外的选项,所以这使得优化开关覆盖了你的“额外选项”-O开关。看来您必须依赖正确的“开发模式”设置。“性能发布”模式将使用-O3而不是-O2。

c++ - ctor 声明/定义中接受的 const 限定符(llvm 错误?)

我的编译器(实际上是AppleLLVM5.0版(clang-500.2.79)(基于LLVM3.3svn))接受(编译)该代码:classX{private:inti;public:constX(){cout它的工作方式就好像没有const限定符引导ctor定义一样。我尝试了-Wall、-pedantic不同类型的标准激活,总是一样的......所以:我错过了什么吗?我没能发现它在最新标准中的句法是正确的……这是gcc/llvm的错误吗?似乎gcc/llvm默默地忽略了const。这是我错过的功能吗?我的示例无法证明它的用处吗?注意:gcc3.4.3不编译它,gcc4.4.5也不编译。

c++ - 抑制 GCC 警告

我有代码:#ifdefQ_OS_LINUX#pragmaGCCdiagnosticpush#pragmaGCCdiagnosticignored"-Wcomment"#include"header.h"#pragmaGCCdiagnosticpop#endif而且我想禁止与header.h和header.h中包含的所有header相关的GCC警告消息。但我仍然收到与header.h中包含的header相关的“-Wcomment”警告。我怎样才能避免这种情况?谢谢海湾合作委员会4.8.2编辑:我收到的警告如下所示:/------SetAnalogOutputfor8022/8026---

c++ - GCC 无法矢量化 64 位乘法。可以在 AVX2 上矢量化 64 位 x 64 位 -> 128 位加宽乘法吗?

我尝试对使用64位加宽乘法的CBRNG进行向量化。static__inline__uint64_tmulhilo64(uint64_ta,uint64_tb,uint64_t*hip){__uint128_tproduct=((__uint128_t)a)*((__uint128_t)b);*hip=product>>64;return(uint64_t)product;}这样的乘法在AVX2中是否以vector形式存在? 最佳答案 没有。没有64x64->128位算术作为vector指令。也没有vectormulhi类型的指令(乘