草庐IT

c++ - GCC ICE——替代函数语法、可变参数模板和元组

(与C++0x,HowdoIexpandatupleintovariadictemplatefunctionarguments?相关。)以下代码(见下文)取自此discussion.目标是将函数应用于元组。我简化了模板参数并修改了代码以允许返回泛型类型的值。虽然原始代码编译正常,但当我尝试使用GCC4.4.3编译修改后的代码时,g++-std=c++0xmain.cc-omainGCC报告内部编译器错误(ICE),并显示以下消息:main.cc:Infunction‘intmain()’:main.cc:53:internalcompilererror:intsubst_copy,at

c++ - GCC 中的元组模板

我首先在VS2010中使用MicrosoftVC++开始使用C++。我最近找到了一些工作,但我一直在使用RHEL5和GCC。我的代码主要是原生C++,但我注意到一件事......GCC似乎无法识别头文件或元组模板。起初我以为这可能只是一个拼写错误,直到我查看cplusplus.com发现该header确实不是标准库的一部分。问题是我喜欢在VisualStudio中编写代码,因为它的环境比eclipse或netbeans更优越、更美观,而且调试也很容易。问题是,我已经编写了大量代码来使用元组,而且我真的很喜欢我的代码。我该如何处理这个问题?这是我的代码:usingstd::cout;us

Boost.Range 的 C++ 元组 - 获取元素类型的元组?

我正在试验Boost.Range和Boost元组。如果我有一个范围元组,我如何键入定义一个元组或相应的元素值?换句话说,我用什么来代替/*?*/:typedefboost::tuples::tuple&,char[]>TupleOfRanges;typedef/*?*/TupleOfElements;我当然可以手工完成,我会写:typedefboost::tuples::tupleTupleOfElements;甚至:typedeftypenameboost::tuples::element::typeRange0;typedeftypenameboost::tuples::eleme

c++ - 调用函数并传递存储在元组中的参数?

我想要一个Foo类来存储它在构造时获得的函数指针,并在某个时候调用这个函数。我查看了这两个问题以寻求帮助:Passtuple'scontentasvariadicfunctionargumentsHowdoIexpandatupleintovariadictemplatefunction'sarguments?然后,根据答案,想出了这段代码:#includetemplatestructapply_func{staticvoidapplyTuple(std::function&f,conststd::tuple&t,ARGS...args){apply_func::applyTuple(

c++ - 是否可以从大括号类型的初始化中推断出元组的模板参数?

在这个例子中,是否可以允许推导元组的模板参数类型?#include#includetemplatevoidfun(std::tuplet,std::stringother){}intmain(){fun(std::tuple(2.,3),std::string("other"));//okfun(std::make_tuple(2.,3),std::string("other"));//ok,buttryingtoavoid`make_tuple`fun({2.,3},std::string("other"));//desiredsyntaxbut//givingcompilation

c++ - 编译器对带有元组参数的函数的混淆

我正在使用Apple的LLVM4.2编译器来编译此C++代码。我用不同的元组组合重载了一个成员函数,我相信我正确地调用了其中一个,但编译器发现了歧义。本质上,我试图调用下面的方法(1),但编译器发现方法(2)也可以接受/兼容。这是为什么?我打开了C++11标志。enumclassEnum1{...}enumclassEnum2{...}enumclassEnum3{...}enumclassEnum4{...}voidmyMethod(){Enum1e1;Enum2e2;Enum3e3;doSomething({e1,e2,e3});//shouldpick(1),yetcompile

c++ - 命名元组元素

我正在开发某种元组结构,我希望允许用户将其元素用作字段,解释:这是我的元组:templatestructmyTuple{std::tupledata;templateinlinetype&get_t(){//typeistheI'thtypereturnstd::get(data);}//Otherstuff};目前用户可以这样使用:structUserStruct{myTuplet;//Otherstuff}并像这样使用它,UserStructob;ob.t.get_t()=0;这有点复杂......所以我这样做了structUserStruct{myTuplet;decltype(

c++ - 当从函数返回元组时,元组的参数被复制而不是 move

我对以下代码有疑问。我的编译器是MSVC++17VisualStudio15.3版,编译器选项为/std:c++14(相对于/std:c++latest),在Release模式下运行:structBar{inta;std::stringb;Bar(){std::coutfoo(){std::strings="dsdf";return{{1,s},{5,"asdf"}};}intmain(){Bara,b;std::tie(a,b)=foo();std::cout输出是:defaultdefaultdirectdirectmovebconstcopyconstcopymoveassign

c++ - 为什么我的 get<k>() 函数不能接收元组的子类?

我在网上复制了一个元组实现,大多数情况下它都能找到:templateclasstuple{};templateclasstuple:publictuple{public:tuple(Tt,Ts...ts):tuple(ts...),tail(t){}Ttail;};templatestructelem_type_holder;templatestructelem_type_holder>{typedefTtype;};templatestructelem_type_holder>{typedeftypenameelem_type_holder>::typetype;};template

c++ - 具有 const 不可复制元素的元组

我需要创建一个std::tuple其中XYZ不可复制。这样的事情甚至可能吗?我当前的代码autotest()->std::tuple{returnstd::make_tuple(XYZ());}在VisualStudio2010中导致C2248...我发现这很可疑,因为我正在构建具有R值的元组,所以我假设移动构造会启动... 最佳答案 您的问题是该元素既不可复制又const.constXYZ元素表现为constXYZ成员;通过5.2.5p4访问constXYZxvalue上的元素将产生具有unioncv资格的xvalue,即具有有效