Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/templates/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 需要在初始化列表中传递不同的类型_C++_Templates_Variadic Templates - Fatal编程技术网

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()
定义会是什么样的?

Make
f
take
std::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);
        }
        // ...
    }
}