C++ 需要在初始化列表中传递不同的类型
我正在寻找一种基于模板的方法来传递初始化列表中任意数量的参数 比如:C++ 需要在初始化列表中传递不同的类型,c++,templates,variadic-templates,C++,Templates,Variadic Templates,我正在寻找一种基于模板的方法来传递初始化列表中任意数量的参数 比如: func({0, 1}, {0, 2.0f}, {0, "boo"}, ...); 或 同时,我希望能够检查每个(内部)大括号中第二个参数的类型。如果constexpr(std::is_same::value)匹配,可能会获得sizeof(T)可能会执行一些 可能吗?如果是这样的话,func()定义会是什么样的?Makeftakestd::initializer\u list: void f(标准::初始
func({0, 1}, {0, 2.0f}, {0, "boo"}, ...);
或
同时,我希望能够检查每个(内部)大括号中第二个参数的类型。如果constexpr(std::is_same::value)匹配,可能会获得sizeof(T)
可能会执行一些
可能吗?如果是这样的话,func()
定义会是什么样的?Makef
takestd::initializer\u list
:
void f(标准::初始值设定项\u列表il){
for(auto it=il.begin();it!=il.end();+it){
const std::type_info&type1=it->first.type();
const std::type_info&type2=it->second.type();
if(type1==typeid(int)){
int val1=std::任意类型(它->第一个);
}
// ...
}
}
如果只有几个可能的类型,可以使用std::variant
而不是std::any
内部大括号总是有两个元素?std::initializer\u list
,其中T
是一个具有重载构造函数的类型?@cigien是的,基本上是一个索引和一个值,确定类型并不一定困难。您想如何处理func
中的所有这些类型?我的计划是将任意类型的变量占用的内存复制到某个不透明的内存区域。获取sizeof(T)需要类型信息才能将大小传递给memcpy。Variant
可能是更好的选择。当你有一个函数可以吃掉任意数量的任意类型时,你可能会遇到设计问题。任何在后端消耗所有这些参数的东西都将是复杂的,并且容易受到错误输入的影响。回到以前的varargs
函数。@user4581301,除了std::any在尝试使用错误类型访问时抛出异常,因此如果没有显式处理其中的对象类型,则最多只能复制它们。不像varargs函数。同意。我需要“几乎回到过去”在那里。
func({{0, 1}, {0, 2.0f}, {0, "boo", ...}});
void f(std::initializer_list<std::pair<std::any, std::any> > il) {
for (auto it = il.begin(); it != il.end(); ++it) {
const std::type_info& type1 = it->first.type();
const std::type_info& type2 = it->second.type();
if (type1 == typeid(int)) {
int val1 = std::any_cast<int>(it->first);
}
// ...
}
}