草庐IT

c++ - 模板化友元函数查找

下面的简单代码可以正常编译classA{intx[3];public:A(){x[0]=1;x[1]=2;x[2]=3;}friendintconst&at(Aconst&a,unsignedi)noexcept{returna.x[i];}friendintfoo(Aconst&a,unsignedi)noexcept{inttmp=at(a,i);returntmp*tmp;}};但是如果把friend做成模板classA{intx[3];public:A(){x[0]=1;x[1]=2;x[2]=3;}templatefriendintconst&at(Aconst&a)noex

c++ - Variadic 模板元编程 : a bug in clang++ or g++?

考虑这种将数组从一种类型转换为另一种类型的疯狂的可变参数模板:#include#includetemplateclassConverter{public:template::type>staticconstexprconststd::arrayconvert(constArraysource,constTypes&...values);template::type>staticconstexprconststd::arrayconvert(constArray,constTypes...values);};templatetemplateconstexprconststd::array

c++ - 使用 cmake、clang 和 llvm 为 visual studio 构建工具链

我在谷歌上搜索了很多,但没有找到合适的答案,所以我在这里问。要从现有代码开发一个应使用cmake和clang编译的c++项目,我需要采取哪些步骤?我还想拥有所有不错的功能,例如自动完成和使用断点进行调试以及逐步调试。 最佳答案 查看与VisualStudio集成的Windows构建的最新LLVM快照页面here.有一个安装程序和一个代码格式化插件。您不会获得自动完成功能,并且Clang/LLVM与VisualStudio中的调试无关(除了如果您使用Clang编译它可能无法工作)。另见thisinterestingblogpost在拥

c++ - clang 和 gcc 中的这个警告似乎不正确

我相信BjarneStroutrup的新书TCPL第4版第66页中的示例有一个小错误,因为classVector_container没有std::initializer_list构造函数。错误信息here证实了这一点。#includeclassVector{double*elem;intsz;public:Vector(ints):elem{newdouble[s]},sz{s}{for(inti=0;i!=sz;++i)elem[i]=0;}Vector(std::initializer_listlst):elem{newdouble[lst.size()]},sz(lst.size

c++ - Clang 为直觉上应该等效的表达式提供非常不同的性能

有人可以向我解释这些表达式之间的这些显着性能差异,我希望它们能提供相似的性能。我在Release模式下使用AppleLLVM版本5.1(clang-503.0.38)(基于LLVM3.4svn)进行编译。这是我的测试代码(只需将CASE更改为1、2、3或4来测试自己):#include#include#defineCASE1inlineintfoo(intn){return#ifCASE==1(n%2)?9:6#elifCASE==2(n%2)==true?9:6#elifCASE==36+(n%2)*3#elifCASE==46+bool(n%2)*3#endif;}intmain(

c++ - 详细类型指的是 Clang 上的 typedef 错误

我在使用此编译器AppleLLVM版本5.1(clang-503.0.40)时遇到以下错误代码在这里测试.hclassmedia{public:typedefenum{audio,video,text,data}mediatype;};测试.cpp#include"test.h"intmain(){enummedia::mediatypemedias[]={media::audio,media::video};for(inti=0;(itest.cpp:5:15:错误:详细类型指的是typedef枚举media::mediatypemedias[]={media::audio,medi

c++ - 集成 LLVM passes

这可能是一个菜鸟问题,但有没有办法集成我的LLVMmodulepass以在转换阶段默认调用?现在我正在使用这个语法来加载我的通行证并注册它~/llvm/llvm/build/Debug+Asserts/bin/clang-Xclang-load-Xclang~/llvm/llvm/build/Debug+Asserts/lib/SOMEPASSLIB.so(问题是当我想用这个pass构建一些包时,编译器在我说时接受它,将加载部分作为CFLAGSenv变量传递,但是一些makefile也使用CFLAGS进行链接,链接器不知道它可以使用此信息做什么并导致构建失败:\)

c++ - C++ 如何处理 try catch block 中的赋值?

我使用clang分析器检查我的C++代码是否存在缺陷和错误。我有以下构造:#include#includedoublesomethingThatMayThrow()throw(std::exception){if(rand()%2){throwstd::exception();}return5.0;}intmain(){doublevalue=2.0;try{value=somethingThatMayThrow();}catch(conststd::exception&){std::cout分析器现在提示变量value的初始值从未被读取。但是,很明显,当且仅当tryblock中出现异

c++ - 地址 sanitizer : "SEGV on unknown adress" when using throw-catch and printf

当我扔东西时,例如一个int或一个charconst*,并使用printf检查错误,我得到一个AddressSanitizerError。我无法在网上找到任何类似的东西,而且我的代码示例非常基础,以至于我真的不明白它怎么可能会产生错误。精简代码示例:#includeintmain(){try{throw42;}catch(intmsg){printf("%d\n",msg);}return0;}运行代码时的控制台输出:ASAN:SIGSEGV===================================================================16533=

c++ - 为什么 std::ios_base::sync_with_stdio 没有在 libc++ (clang) 中实现?

让我们看一下这个代码示例:#includeintmain(){std::ios_base::sync_with_stdio(false);intn;std::cin>>n;for(inti=0;i>buf;}}此代码示例对这样的输入的性能:1000000001...9999999在我的机器上:g++-5-O2-std=c++11:./a.outclang-700.0.72-O2-std=c++11:./a.out经过一些分析后,我发现libc++根本没有禁用同步。然后我查看了他们的代码,发现了这个:https://github.com/llvm-mirror/libcxx/blob/6