9

我喜欢 c++11 可变参数模板,所以我经常用它写一些小代码。

看这个例子:

#include <cstdio>
#include <type_traits>
#include <vector>

template< typename ... T >
auto make_vector(T ... t ) -> std::vector< typename std::common_type<T...>::type >
{
    std::vector< typename  std::common_type<T...>::type > v;
    v.reserve( sizeof...(T) );

    using list = int[];
    (void)list{ 0, ( (void)v.push_back(std::move(t)) ,0)... };
    //                |/ / / /
    //                --------
    //                 \-- How are evaluated v.push_back()s, sequentially or arbitrary ?
    return v;
}

int main()
{
    auto v = make_vector(2, 3.0, 'a', 7UL );

    for(auto e : v )
      printf("%.2lf ", e);

    printf("\n");

}

问:数组初始化的评估顺序是顺序的还是任意的(或实现定义的,未定义的行为)?

如果make_vector 错了,我该如何解决?

4

1 回答 1

12

它们按顺序进行评估。C++11 § 8.5.4 [dcl.init.list] 第 4 段:

花括号初始化列表的初始化列表中初始化子句包括任何由包扩展 (14.5.3) 产生的子句,按照它们出现的顺序进行评估。

鉴于它vector有一个initializer_list构造函数,您可以将函数简化为:

template <typename ... T>
auto make_vector(T ... t) ->
  std::vector< typename std::common_type<T...>::type >
{
  return { static_cast<typename std::common_type<T...>::type>(t)... };
}

并且不必担心神秘的初始化语义;)

于 2013-11-25T07:27:21.323 回答