草庐IT

iphoneos-clang

全部标签

c++ - 在 GCC 4.7.2 和 Clang 3.2 中显然缺少 getline() 的重载,将 RRef 流式传输

我在尝试将getline()与临时流对象一起使用时遇到了意外的编译错误:#include#include#includeusingnamespacestd;intmain(){stringinput="hello\nworld\nof\ndelimiters";stringline;if(getline(stringstream(input),line))//ERROR!{cout看起来不存在接受对流对象的右值引用的getline()重载。如果我将main()更改为使用左值,它会按预期编译和运行:intmain(){stringinput="hello\nworld\nof\ndeli

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++ - 为什么 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

c++ - 特征矩阵初始化的 clang 格式

例如要初始化Eigen::Matrix3i我们可以使用语法:Eigen::Matrix3iT;T但是,当使用clang-format(在我的例子中是3.6)和Google样式时,这个漂亮的初始化变成:Eigen::Matrix3iT;T有没有简单的方法可以避免这种情况?有没有办法告诉clang-format跳过这样的东西? 最佳答案 看来您唯一的选择是使用相当丑陋的clang格式切换语法:Eigen::Matrix3iT;//clang-formatoffT 关于c++-特征矩阵初始化的

c++ - 无法获取要在 Visual Studio 和 clang 下编译的模板

我有以下缩小代码。带有//OnlyVS的行在VS上编译但在clang上不编译,带有//Onlyclang的行在clang上编译,但在VS上不编译。谁是正确的?更重要的是,如何在两者上编译等效行?测试的版本是clang3.7.0,VS2015。#include#includetemplateclassC{structB{std::functionfunc;B(std::functionfunc):func(func){}};templatestructD:B{usingB::B;templatevoidCall(T&t,std::index_sequence){func(std::get

c++ - Clang 和 GCC 在解析可变函数模板重载时的不同行为

考虑这段代码:#includeintfoo_i(intx){returnx+1;}charfoo_c(charx){returnx+1;}usingII=int(*)(int);usingCC=char(*)(char);templatestructfn{Ff;templatedecltype(auto)operator()(Args&&...args)const{returnf(std::forward(args)...);}};structfn_2:privatefn,privatefn{fn_2(IIfp1,CCfp2):fn{fp1},fn{fp2}{}usingfn::ope