如何为用户定义的类型实现初始化列表? (类似于std :: vector初始化列表)

时间:2013-05-09 05:31:44

标签: c++ c++11 initializer-list

std::vector可以初始化为

std::vector<std::string> words1 {"the", "frogurt", "is", "also", "cursed"}; 

Reference

现在,如果想要为我的某个类型实现类似的功能,我该如何去做呢?我该如何实现此功能的构造函数?

该标准如何支持我实现这一目标(参考标准将是最有帮助的)?基本上,如果你可以教我如何为std::vector实施它就足够了。

这可以在C ++ 11之前完成吗?

另外,我可以使用POD结构类型初始值设定项列表,以便我可以使用不同类型的值来初始化我的类型吗?

2 个答案:

答案 0 :(得分:24)

创建一个以std::initializer_list作为参数的构造函数:

#include <vector>
#include <initializer_list>

template <typename T>
struct foo
{
private:
    std::vector<T> vec;

public:

    foo(std::initializer_list<T> init) 
      : vec(init)
    { }
};


int main()
{
    foo<int> f {1, 2, 3, 4, 5};
}

std::vector这几乎完全相同(尽管使用begin()end() - std::initializer_list迭代器的方式与其他容器的方式大致相同)。来自gcc

  vector(initializer_list<value_type> __l,
     const allocator_type& __a = allocator_type())
  : _Base(__a)
  {
_M_range_initialize(__l.begin(), __l.end(),
            random_access_iterator_tag());
  }

编辑:我不是100%你想要做的事情,但你可能只是能够使用统一初始化来获得你想要的东西:

struct bar
{
private:

    int i;
    double j;
    std::string k;

public:

    bar(int i_, double j_, const std::string& k_)
      : i(i_), j(j_), k(k_)
    { }

};

int main()
{
    bar b {1, 2.0, "hi"};
}

答案 1 :(得分:-1)

如果有人仍在寻求该问题的另一个答案,那么您可以从typeid中受益,例如:

template <typename Type>
void check_type( Type par ){
   if( typeid(Type) == typeid(std::string()) ) {} //check for string type
   if( typeid(Type) == typeid(int) ){} //is int

}