草庐IT

c++ - 任意但编译时已知数量的类型的元组

假设我有一个由另一个完整的POD类型参数化的类型:templatestructMyFoo{/*...*/};有了它,就有可能拥有它们的元组:typedefstd::tuple,MyFoo,MyFoo>Foo3;但是现在,我想要一个类型“Foo”,其中N是constexpr.一种实现类似于Foo的方法会是:templatestructFoos;templatestructFoos{typedefstd::tuple>type;};templatestructFoos{typedefstd::tuple,MyFoo>type;};/*continuewiththis....*/即为我想要的

将函子推入元组

我简化了我需要的某些代码的类型签名,看起来大致是这样:Functorf=>f(Maybea,b)->(Maybe(fa),fb)我可以如何实现这样的功能?如果是这样,怎么样?我一半猜想我需要使用Traversable,但是我很难将所有这些放在脑海中。看答案如果它是可穿越的,而不是函子,我们可以做。fn::Traversablet=>t(Maybea,b)->(Maybe(ta),tb)fnv=(sequenceA$fmapfstv,fmapsndv)可以吗?

c++ - 如何构建一个元组 vector 并像对一样对它们进行排序?

假设,我有几个像这样的整数元素:(391),(152),(283),(144),(165),(156)现在我想对元素进行排序,例如对vector进行排序。唯一不同的是,这里我们有3个键,而不是2个键。排序后的元素将如下所示:(144),(152),(156),(165),(283),(391)是否有任何STL或其他技术可以实现此目的?我发现了元组,但在理解它时遇到了一些问题。你们能以任何方式帮助我吗?可能是通过提供有用的链接或解释过程。 最佳答案 Avector的tuple如果需要,可以只使用STL进行排序。#include#inc

c++ - 在 C++17 中定义可变坐标(元组)类型?

我想定义一个可变元组类型来表示坐标。例如,对于某些魔法类型:templatestructCoordT{typedefstd::tuplecoord_type;};我想要CoordT::coord_type成为3维坐标类型:std::tuple.但是我不知道如何使用模板编程来生成N重复double谁能帮忙解释一下怎么写? 最佳答案 使用std::make_integer_sequence生成适当长度的包,然后将元素映射到double值:templatestructTupleOfDoubles{templatestaticautofoo

c++ - c++0x 元组是否使用新的可变参数模板或 Boost 的宏元组实现?

我读到它基于Boost的版本,但我不太确定具体到实现时这意味着什么。我知道Boost有自己的可变参数模板,但我认为c++0x会为新元组使用它自己的可变参数模板。 最佳答案 C++0x标准草案中的tuple使用C++0x可变参数模板。它被声明为(§20.4.1):templateclasstuple;但是请注意,TR1语言扩展还包括tuple,它不使用可变参数模板,因为在编写TR1时没有这样的东西。在TR1中,tuple声明为(§6.1):templateclasstuple;其中M是一些实现定义的值,应该至少为10。TR1并不是C+

C++ 使嵌套元组 "plain"/"flatten"

问题:使元组的元组“简单”的最佳方法是什么?例如。一维。案例1templateautoprocess_field(Field&&field){//oranotherstd::get(field)...returnstd::forward_as_tuple(field.fst,field.snd,field.thrd,field.fth);}templateautoiterate_record(std::index_sequence,Rec&&rec){returnforward_as_tuple(process_field(std::get(forward(rec).data))...

c++ - 将 C++ 字符串解析为元组

我正在开发一个简单的CSV解析器,它将文件的行存储在一个元组中。如果不是因为文件中各行的条目数及其类型都是变量,这将是一项简单的任务。因此,这些行可能是这样的:1,2.2,你好,18,世界解析器应该能够像这样工作:ifstreamfile("input.csv");SimpleCSVParserparser(file);当我尝试实现一个函数来解析实际行时,事情变得复杂了。我仍然没有找到一种方法来从参数列表中提取下一个类型以在调用file>>var之前声明变量。我还需要在循环中执行此操作,以某种方式从每次迭代的结果构建一个元组。那么如何使用纯C++11将字符串解析为元组?我试过这个:te

c++ - 创建一个包含可变类型的元组

今天我试图在编译时创建一个有点具体(至少对我而言)的元组。我有一些基本的结构,比方说:structFoo1{intdata;};structFoo2{intdata;};structFoo3{intdata;};还有另一个结构,但带有一些模板内容:templatestructMetadata{usingtype=T;std::bitsetbitset;};所以现在我想创建这种元组:constexprstd::tuple,Metadata,Metadata>test{{0},{0},{0}};但以一种自动的方式,更像是:templateconstexprautomake_metadata

c++ - 将函数的返回值存储在元组中

考虑#includetemplateautoexecute(F...f){returnstd::make_tuple(f(0)...);}intfoo(int){return5;}intbar(int){return3;}intmain(){autotuple=execute(foo,bar);}有什么好的解决方法可以让bar返回void?我试过这个,但它不会编译:#includestructVoid{};templateTcheck(Tn){returnn;}Voidcheck(void){returnVoid{};}templateautoexecute(F...f){return

c++ - 使用 "if constexpr"防止元组越界

以下代码在GCC和Clang下编译良好,但在VisualStudio(/std:c++latest)的最新更新中停止工作:#includetemplatevoidcheck_tuple(T...types){ifconstexpr(pos>::type;}}intmain(){check_tuple(1.0,1.0);check_tuple(1.0,1.0);}在最新版本的VisualStudio(/std:c++latest)中,编译失败,元组索引越界(std::tuple_element>)。是否可以像这样使用constexpr来防止元组越界? 最佳答案