关于模板中泛型初始化的c++
C++ about generic initialization in templates
我正在写一个像下面这样的泛型函数。
template<class Iterator, class T>
void foo(Iterator first, Iterator last) {
T a;
cout << a << endl;
// do something with iterators
}
typedef vector<double>::iterator DblPtr;
vector<double> values;
foo< DblPtr, int>();
这个函数为变量a
打印一个未定义的值,而如果我将初始化更改为
///
T a = T()
cout << a << endl;
// do something with iterators
我可以看到初始化的值是0
,正如我所期望的。
如果我调用T a
,变量初始化为默认值,但如果我调用T a = T()
,我相信由于优化,复制构造函数应该调用T()
的值,这仍然是默认的。
我不明白这两行背后的区别是什么,为什么会发生这种情况?
首先,内置类型(如int
)的默认初始化使它们未初始化。值初始化使它们为零初始化。至于你的例子
这是一个默认初始化:
T a;
这是一个值初始化,使用复制初始化:
T a = T();
你是对的,副本可以在这里省略,所以这有创建单个值初始化的T
对象的效果。然而,它确实要求T
是可复制的或可移动的。这是内置类型的情况,但要记住这是一个限制。
复制初始化语法是必需的,因为这是一个函数声明:
T a();
但是c++ 11允许像这样进行值初始化:
T a{};
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员