草庐IT

CLANG_ARGS

全部标签

c++ - Xcode 4.5 和 OpenMP with Clang (Apple LLVM) 仅使用一个内核

我们在一个C++11项目上使用Xcode4.5,我们使用OpenMP来加速我们的计算:#pragmaompparallelforfor(uintx=1;x虽然事件监视器显示程序使用了多个线程,但我们观察到只使用了一个内核:我们还在使用GCC4.7的Ubuntu上运行相同的代码,我们观察到所有内核上的争用。可能是AppleLLVM中删除了OpenMP支持吗?是否有OpenMP的替代方案?我们无法切换到GCC,因为我们使用C++11功能。 最佳答案 编辑:此答案现已部分过时。现代ClangsupportOpenMP,只是不是Apple随

c++ - AFAIK,下面的代码不应该编译,但它在 clang 和 GCC 中编译。我在这里错过了什么?

下面的代码显示了一个带有非平凡默认构造函数的类union类(成员y是用brace-or-equal-initializer初始化的),所以如果默认了此类类的默认构造函数,则应根据§12.1/5第一个要点将其删除。也就是说,声明Tt;不应编译,因为unionT没有默认构造函数。但是codecompilesandexecutes在clang和GCC中。#includeunionT{inty{1};floatx;charc;T()=default;};intmain(){Tt;std::cout编辑我上面的问题从一开始就错了,因为unionT不是类union类。我刚刚了解到C++11中的§9

c++ - Clang 与 gcc std::crbegin with boost::iterator_range

使用libc++的Clang3.8.1编译以下程序:#include#include#include#include#includeintmain(){conststd::vectorv{1,2,3};constautorange=boost::make_iterator_range(v);std::copy(std::crbegin(range),std::crend(range),std::ostream_iterator{std::cout,""});std::cout但是带有libstdc++的gcc6.1.0没有。gcc错误的第一行是:error:nomatchingfunc

c++ - 关于 C++ 编译器的几个问题 : GCC, MSVC、Clang、Comeau 等

我有几个关于C++编译器的问题C++编译器是否需要one-passcompiler?标准是否在任何地方谈论它?特别是GCC是一次性编译器吗?如果是,那么为什么它会在thisexample中生成以下错误两次(尽管每个错误消息中的模板参数都不同)?error:declarationof‘adderitem’shadowsaparametererror:declarationof‘adderitem’shadowsaparameter一个更一般的问题one-passcompiler的优点和缺点是什么?和multi-passcompiler?有用的链接:AListofC/C++compiler

c++ - clang 3.3 和 GCC 4.7 const v 的 constexpr

我刚刚尝试在Ubuntu13.04上使用带有GCC4.7.3标准库头文件的clang3.3编译大量代码。这一切都很顺利,除了一个问题。这段代码已经在这台机器上用标准的Ubuntuclang3.2包编译,所以我假设这是clang3.3编译器的一些变化。与使用复杂header的const和constexpr有关的问题。特别是复杂类型具有以下代码块#ifdef__GXX_EXPERIMENTAL_CXX0X__//_GLIBCXX_RESOLVE_LIB_DEFECTS//DR387.std::complexover-encapsulated.constexprdoublereal(){re

c++ - 使用折叠表达式将参数包扩展到 lambda - gcc vs clang

考虑以下代码片段:templatevoidpost(TF){}templatestructfuncs:TFs...{funcs(TFs...fs):TFs{fs}...{}voidcall(){(post([&]{static_cast(*this)();}),...);}};clang++3.8+successfullycompilesthecode.g++7.0failstocompile出现以下错误:prog.cc:Inlambdafunction:prog.cc:10:43:error:parameterpacksnotexpandedwith'...':(post([&]{s

c++ - OS X clang -pthread

在OSX中使用带有clang的pthread库的编译器/链接器要求是什么。对于GCC,我知道使用-pthread设置适当的编译器/链接器选项,但我不确定OSX是否带有clang。air:~jose$clang++-ctest.cpp-pthreadair:~jose$clang++-otest-pthreadtest.oclang:warning:argumentunusedduringcompilation:'-pthread'air:~jose$g++-ctest.cpp-pthreadair:~jose$g++-otest-pthreadtest.o

c++ - 此类代码中 gcc 和 clang 之间的不同行为

intmain(){std::vectordelimiters={",",";"};std::cout我在gcc和clang之间得到不同的答案clang7.0.0打印出来,gcc8.2.0报错terminatecalledafterthrowinganinstanceof'std::length_error'what():cannotcreatestd::vectorlargerthanmax_size()Aborted哪个编译器是正确的? 最佳答案 两个编译器都是正确的,因为你的代码有未定义的行为。你掉进了陷阱。{",",";"}

c++ - clang 等同于 -rdynamic gcc 标志是什么?

我找不到任何类似的选项可以将所有函数名称包含到最终发布的二进制文件中。还是clang默认执行此操作? 最佳答案 这道题的正确答案是-Wl,-export_dynamic而不是-Wl,--export-dynamic。-Wl,--export-dynamic只有在ELF平台上使用GNU链接器时才是正确的。这个问题是关于OSX的。来源:http://www.opensource.apple.com/source/ld64/ld64-236.3/src/ld/Options.cpp...elseif(strcmp(arg,"-export

c++ - 这是 clang++/g++ 中的错误吗?

这个问题在这里已经有了答案:Whydoesthetemplate-idin"A=0"notcompilewithoutspacebecauseofthegreater-or-equal-thanoperator">="?(1个回答)关闭4年前。给定:voidfunction(int*=0){}intmain(){}clang(3.8.0):test.cc:1:18:error:expected')'voidfunction(int*=0){^g++(5.4.0):test.cc:1:18:error:expected‘,’or‘...’before‘*=’tokenvoidfuncti