草庐IT

c++ - 初始化不可复制和不可移动类的元组

考虑具有唯一自定义构造函数的类A:classA{public:A(float){}private:A()=delete;A(constA&)=delete;A(A&&)=delete;};还有另一个类B,它包含A的一个元组(为简单起见,让它成为唯一的元组成员):classB{public:B():ta(0.0f){}//tainitializationOKprivate:std::tupleta;};现在我们可以声明B的一个对象,它工作正常:Bb;但是如果A的构造函数有多个参数,如何做同样的事情呢?classA{public:A(float,int){}private:A()=dele

c++ - 结构化绑定(bind)和引用元组

我在设计一个简单的zip函数时遇到了一个问题,可以这样调用:for(auto[x,y]:zip(std::vector{1,2,3},std:vector{-1,-2,-3}){//...}所以zip将返回类型为zip_range的对象,本身暴露begin和end返回zip_iterator的函数.现在,一个zip_iterator,正如我实现的那样,使用std::tuple-其中Iterators是压缩容器迭代器的类型-以跟踪其在压缩容器中的位置。当我取消引用zip_iterator时,我获得了对压缩容器元素的引用元组。问题是它不适合结构化绑定(bind)语法:std::vector

c++ - 从元组函数一次存储 2 个变量

我有一个元组函数,它返回一个形式为的元组有没有一种方法可以在不创建另一个元组的情况下一次存储2个值。我知道我们可以做到n,score=tuplefunct(abc);在python中。但是如果我想在C++中存储两个返回值而不创建另一个元组,我需要调用两次n=get(tuplefunct(abc);score=get(tuplefunct(abc));在C++中是否有任何替代方法来一次存储值。 最佳答案 您不需要调用该函数两次(请注意,不涉及“另一个元组”,该函数返回一个,这就是您使用的):autox=tuplefunct(abc);

C++容器/数组/元组一致访问接口(interface)

是否存在跨容器工作的一致元素访问语义(也许在boost中)?类似的东西:element_of(std_pair).get();element_of(boost_tuple).get();element_of(pod_array).get();原则上我可以自己写,但我不想重新发明轮子。谢谢 最佳答案 容器有不同的访问方式,因为它们本质上是不同的。在STL中最接近的是迭代器。所有标准容器都有迭代器,因此您可以迭代它们并使用这些迭代器对它们使用相同的算法。但是,每个迭代器包含的内容因容器而异(必须只有元素,但映射有对)。如果您将pair视

c++ - boost 元组+变换

是否可以做到以下几点。假设我的boost元组有我想使用std::transform+mem_fun仅将std::string元素插入相应的vector中。是否有可能或者我们需要使用循环和push_back(get)...即以下不喜欢编译...(未知类型...)result.resize(storage.size())std::transform(storage.begin(),storage.end(),result.begin(),std::mem_fun(&boost::get));这是一个例子(尝试其中一个评论):#include#include#include#include#

c++ - 如何递归元组?

我正在尝试制作一个可变参数模板容器,用于存储元素vector的元组。这个容器的要点是所有vector中的元素都是相关的,我想在以后保持这种相关性,但这不是计算所必需的。想象一下,如果你愿意的话,一个vector_3和一个某种类型的ref_id。容器只会一起统一变异vector。所以我理解的部分看起来像这样:templateclasscontainer{std::tuple...>data_;public:templateconsttypenamestd::tuple_element::type&nth_index()const{returnstd::get(data_);}};我正在努

c++ - 通过模板成员函数访问私有(private)元组元素

这个问题在这里已经有了答案:WhereandwhydoIhavetoputthe"template"and"typename"keywords?(8个答案)关闭6年前。类(class)foo包含一个私有(private)元组成员。我想使用getElement()获取对此元组元素的引用.我找到了这个解决方案,但是当对象被传递给另一个类的构造函数时它不起作用bar:#includetemplateclassfoo{std::tupletup_;public:foo(Args...args):tup_{args...}{};templateconsttypenamestd::tuple_el

c++ - 在 C++11 中替换元组中的类型

我正在尝试使用C++中的模板来执行以下操作:我有这样一个函数:templatevoidf1(conststd::tuple&t1);在此函数内,我想创建另一个元组t2,以便将t1的每个元素都复制到t2的相同位置,A类型的元素除外,t2应为此创建B类型的对象。但是,B的构造函数引用了一个类型为A的对象以及类型为的第二个参数C&。C的实例在转换之前创建,并且在遇到A类型的对象时应作为第二个参数传递给B的构造函数.像这样,只是完全概括:std::tupleConvert(std::tupletpl,C&c){returnstd::tuple(std::get(tpl),B(std::get(

c++ - 元组查找函数参数替换失败

所以,我在休息一段时间后才回到C++,我想也许我应该写些有趣的东西。在这里,我想到了搜索元组容器并在元组的第N个元素满足要求(值或一元函数)时返回迭代器的函数。所以,这是我现在写的:templateclassContainer,templateclassTuple,typename...TupleArgs>autofind(typenameContainer>::iteratorit1,typenameContainer>::iteratorit2,decltype(std::get(std::declval>()))searchedValue){for(;it1!=it2;++it1

C++:将元组转换为类型 T

我正在尝试创建一个名为tuple_cnv的类,它带有一个(隐式)转换运算符以从元组构造任何对象(如C++17std::make_from_tuple函数),但具有递归性质,以这种方式,如果一个元组由其他元组组成,它会将任何“内元组”转换为tuple_cnv以允许递归就地构造目标类型:#include#include#include#includestructA{inti1,i2,i3;};structB{Aa1,a2;};templatestructtuple_cnv;templatestructtuple_cnv>{usingtuple_t=std::tuple;std::refer