草庐IT

CLANG_ARGS

全部标签

c++ - clang 中带有 std::async 的模板函数

我正在查看std::async的示例here,如下:#include#include#include#include#includetemplateintparallel_sum(RAIterbeg,RAIterend){autolen=std::distance(beg,end);if(len,mid,end);intsum=parallel_sum(beg,mid);returnsum+handle.get();}intmain(){std::vectorv(10000,1);std::cout我尝试使用Clang3.4的网络编译器对其进行编译,结果输出的是Thesumis而不是预

c++ - std::atomic 不受 clang 支持?

我正在尝试将std::atomic与clang一起使用。但是,每当我尝试包含头文件原子(#include)时,我都会收到消息“找不到原子”。请注意,我包括-std=c++11-stdlib=libc++编译时。我错过了什么?我使用的clang版本是3.2。 最佳答案 TheversionofclangI'musingis3.2.Clang根据LLVMCXXStatus添加了跨两个不同版本的原子支持.第一个是Clang3.1,第二个是Clang3.2。我认为您可以使用以下方式检查它:#ifdefined(__clang__)#if__

c++ - gcc 和 clang 不同意 constexpr 函数

从生成器函数编写一个简单的编译时std::array工厂,我偶然发现了这个:clang++3.5.1和g++4.9.2不同意函数是否是constexpr或不。代码(这是c++14!):#include#includetemplateconstexprstd::arraymake_array_impl(GenTypegen,std::index_sequence){return{{gen(I)...}};}templateconstexprstd::arraymake_array(GenTypegen){returnmake_array_impl(gen,std::make_index_

c++ - 从 clang-format 样式中提取 emacs c 样式选项

一位同事为我正在处理的C++项目提供了一个clang格式的样式文件。我安装了clang-format.el为了能够从emacs格式化缓冲区。重新格式化按预期工作。不过,Emacs默认的c模式缩进仍然完全不同。我发现在编辑时破坏源代码格式并在以后恢复它非常令人不安。有什么方法可以读取clang格式的文件并应用相应的cc模式选项? 最佳答案 不知道有没有直接转换工具。但是,您可以尝试使用以下技巧:将项目中相当数量的C++文件连接成一个文件(例如cat*.cpp>single.cpp)将clang-format应用到single.cpp在

c++ - clang 的 uint24_t 是如何工作的?我可以在 clang/LLVM 之外使用它吗?

作为GCC用户,我刚刚注意到clang支持uint24_t类型(它在他们的stdint.h中)。这是如何运作的?我的意思是,它是纯粹在内部支持,作为一种语言扩展,还是像C++类那样实现,具有超过3个字节或16位值和另一个8位值的抽象?并且-怎么可能通过GCC来“猛拉”这样的实现并自己使用它?注意:我希望在现代C++中有一个类似uint24_t的类(或更一般的uint_t);我的替代方案是自己动手。你可以s/uint/int/g;如果你喜欢这个问题。 最佳答案 这不是可移植的或标准的。它仅适用于AVR(具有24位地址)和GCChasi

c++ - 有没有办法在 g++/clang++ 中使用自定义修改?

当使用C++模板,尤其是元组时,我经常会得到很长的错位名称,例如_ZN11__sanitizer13InternalAllocEmPNS_28SizeClassAllocatorLocalCacheINS_20SizeClassAllocator32ILm0ELy140737488355328ELm0ENS_12SizeClassMapILm3ELm4ELm8ELm17ELm64ELm14EEELm20ENS_15TwoLevelByteMapILy32768ELy4096ENS_20NoOpMapUnmapCallbackEEES5_EEEEm这在标称情况下显然很好,并且易于调试,但

c++ - 是否可以从 clang 的解析树中提取预处理器信息?

考虑以下简单的头文件demo.h:#definePERSISTstructSerialised{intsomeTransientValue;PERSISTintaNumberToPersist;};我使用以下代码和Clang的pythonAPI来迭代header:importsys,clang.cindexdefcallexpr_visitor(node,parent,userdata):ifnode.location.file:printnode.location.file,node.displayname,node.kindreturn2tu=clang.cindex.Index.

c++ - 强制 clang 为类模板实例化的从未引用的静态成员函数发出代码

我可以使用used和noinline在gcc中轻松实现此目的functionattributes(见下面的代码),但这在clang中不起作用,即使它应该支持这两个函数属性。一个简化的例子:templatestructFactory{static__attribute__((used,noinline))TcreateFoo(){returnT();}};intmain(){Factoryf;//instantiateanduseFactory}编译gcc中的代码并使用nm确认gcc正确发出函数:nm--demangletest|grepcreateFoo0000000000403185

c++ - 如何在预处理时可靠地检测 clang 的版本?

显然,与Xcode捆绑在一起的clang不遵守上游__clang_major__和__clang_minor__值,而是报告某种面向用户的Xcode版本。这里是clang的各种MacPorts安装的值,以供引用。他们似乎尊重上游版本标识符。我在Linux上测试时得到了类似的值。➜prohibit-clang-3.2/opt/local/bin/clang++-mp-3.2-dM-E-xc/dev/null|grep__clang_m#define__clang_major__3#define__clang_minor__2➜prohibit-clang-3.2/opt/local/bi

c++ - 是什么导致 clang 找不到 unordered_map header ?

我正在尝试使用Clang++编译我在网上找到的程序。Makefile生成此命令:clang++-c-archx86_64-msse3-std=c++11-stdlib=libstdc++-Wno-missing-field-initializers-Wno-missing-prototypes-Wreturn-type-Wno-non-virtual-dtor-Wno-exit-time-destructors-Wformat-Wmissing-braces-Wparentheses-Wno-switch-Wunused-function-Wunused-label-Wno-unuse