草庐IT

c++ - GCC 是否优化 std::tie 仅用于可读性?

假设我有一个std::tuple:std::tuplet={1,2,3,4};我想使用std::tie只是为了这样的可读性目的:inta,b,c,d;//inrealcontextthesenameswouldbemeaningfulstd::tie(a,b,c,d)=t;对比只使用t.get(0)等GCC会优化这个元组的内存使用还是会为a,b,c,d分配额外的空间?变量? 最佳答案 在这种情况下,我看不出有任何理由不这样做,在as-ifrule下编译器只需要模拟程序的可观察行为。快速实验usinggodbolt:#include#

c++ - 在 C++11 中构建 union 元组

元组是一种likestructs.是否也有表现得像union的元组?或者我可以在元组中访问成员的union,例如my_union_tupleu;get(u);get(u);//C++14only,orseebelow对于第二行,请参阅here.当然,该解决方案不仅适用于特定的union,例如,但对于任意类型和类型数量。 最佳答案 没有std::tuple表示A和B。如果您想要一个类型安全的类union容器,请查看boostvariant.boost::variantv;v="hello";std::cout它确实为游客提供了安全的交

c++ - 交换引用的临时元组

我正在编写一个自定义迭代器,它在取消引用时返回一个引用元组。由于元组本身是短暂的,我认为我无法从operator*()返回引用。我认为我的迭代器在语义上是有意义的,因为它具有引用语义,即使operator*返回一个值也是如此。问题是,当我尝试调用std::swap时(或者更确切地说,当std::sort调用时),如下所示,我收到错误,因为交换需要左值。有解决此问题的简单方法吗?#includeclasstest{public:test():v1(10),v2(10){}classiterator{public:iterator(std::vector&_v1,std::vector&_

c++ - 将从元组派生的对象放入 C++ 中的 vector 中

我想创建一个包含3个值的结构:一个字符串和两个整数。该字符串是强制性的,但其中一个(或两个)整数是可选的,如果未指定则可以默认为-1。但是,与其使用结构,不如尝试使用std::tuple。为了合并两个整数的可选性,我设置了一个继承自std::tuple的“Trio”类,如下所示:#include#includeclassTrio:publicstd::tuple{public:explicitTrio(std::stringconst&name,intval1=-1,intval2=-1):tuple(name,val1,val2){}};然后我通过将一些Trio对象插入std::ve

c++ - 可变参数聚合作为核心语言功能

std::tuple是高度模板加载的野兽。要访问第n个成员,编译器必须执行大量模板实例化,尽管它的性质很简单:访问相应虚构结构的第n个数据成员。看起来std::tuple应该是一个核心语言特性,像这样(伪代码):templatestruct/*orclass,orevenunion*/V{types...V;//definesimplicitly`operator[/*constantexpression*/]`toaccessbyindex//ifmorethanonevariadicparameterpackprovided//(duringexpandingofparameter

c++ - 元组实现是否有优化的布局?

阅读时this我对某种级别的元编程可以为您的类布局做些什么感到惊讶。我必须承认,我没有完全理解建议的最佳布局是什么,如果我必须说明我的理解,那就是:orderingclassmemberbydescendingalignmenti.e.thetypewiththegreatestalignofresultgoesfirstetc如果我弄错了,请随时纠正我(如果您能简短地解释为什么会发生这种情况,那就更好了,我无法在我的问题中复制粘贴大量的基本原理),但我的问题是关于另一个主题:std::tuple的库实现有这样的布局优化吗?如果没有,是否有任何标准代数数据类型可以这样做,除了编写这样的

c++ - std::tuple 和 boost::tuple 之间的转换

给定一个boost::tuple和std::tuple,你如何在它们之间进行转换?也就是说,您将如何实现以下两个功能?templateboost::tupleasBoostTuple(std::tuplestdTuple);templatestd::tupleasStdTuple(boost::tupleboostTuple);看起来很简单,但我找不到任何好的解决方案。我尝试了什么?我最终用模板编程解决了这个问题。它似乎适用于我的具体设置,但感觉不对(太冗长),我什至不确定它是否真的适用于所有情况(我稍后会谈到这一点)。无论如何,这是有趣的部分:templatestructCopySt

c++ - 如何将 std::tuple 类型与 boost::mpl 算法一起使用?

boost::mpl算法似乎无法在开箱即用的std::tuple类型上工作,例如,以下不编译(boost-1.46.0,g++快照2011-02-19):#include#include#includenamespacempl=boost::mpl;typedefmpl::vectortypes;static_assert(mpl::contains::value,"vectorcontainsbool");typedefstd::tupletypes2;//thefollowingdoesnotcompile://error:noclasstemplatenamed‘apply’in

c++ - 空嵌套元组错误

#include#includeintmain(){autobt=std::make_tuple(std::tuple(),std::tuple>());//Line1autobt2=std::make_tuple(std::tuple(),std::tuple());//Line2}为什么第1行给出编译错误,而第2行编译正常?(在Gcc和Clang中测试)是否有可能的解决方法?clang的错误信息/usr/include/c++/4.6/tuple:150:50:error:ambiguousconversionfromderivedclass'std::_Tuple_impl,st

c++ - 是否可以简单地复制::std::tuple-like 类模板?是否存在实现?

我需要一个简单可复制的类似元组的类,但不存在合适的实现,我自己想不出一个,我认为甚至不可能。原因是引用。::std::tuple可以保存引用,但平凡可复制的元组可能不能,因为它可能没有非平凡的构造函数,并且必须在构造函数中初始化引用类似元组的类并存储引用包装器将使类似元组的类变得不平凡。我的问题在标题中。 最佳答案 使用reference_wrapper存储引用是entirelypossible:std::reference_wrapperisguaranteedtobeTriviallyCopyable.(sinceC++17)只