我见过有人在初始化列表中的成员变量后面加上括号。我想知道为什么人们会这样做?
例如,我在头文件中有一个 STL 容器:
class A{
public:
A();
...
private:
vector<string> v;
}
在源文件中:
A::A() : v() {}
我的问题是什么是 v() 以及为什么人们这样做,因为看起来 v 也没有被初始化为一个值
我见过有人在初始化列表中的成员变量后面加上括号。我想知道为什么人们会这样做?
例如,我在头文件中有一个 STL 容器:
class A{
public:
A();
...
private:
vector<string> v;
}
在源文件中:
A::A() : v() {}
我的问题是什么是 v() 以及为什么人们这样做,因为看起来 v 也没有被初始化为一个值
这将为成员运行默认构造函数或初始化程序(对于普通类型)。在这种情况下,它将默认构造向量。由于是默认构造函数,这里就不需要了。v
在没有初始化程序的情况下会默认构造。
class Example {
private:
int defaultInt;
vector<int> defaultVector;
int valuedInt;
vector<int> sizedVector;
public:
Example(int value = 0, size_t vectorLen = 10)
: defaultInt(), defaultVector(), valuedInt(value), sizedVector(vectorLen)
{
//defaultInt is now 0 (since integral types are default-initialized to 0)
//defaultVector is now a std::vector<int>() (a default constructed vector)
//valuedInt is now value since it was initialized to value
//sizedVector is now a vector of 'size' default-intialized ints (so 'size' 0's)
}
};
对于踢腿和咯咯笑声,您还thirdVector(vectorLen, value)
可以获取vector
带有vectorLen
value 的元素value
。(所以Example(5, 10)
会制作thirdVector
一个10
元素向量 value 5
。)
My question is what is v() and why do people do that since that doesn't look like v is initialized into a value either
有时这样做是为了更明确。对于非 POD 类型,这不是必需的,因为会自动为它们调用默认构造函数。如果类型默认构造函数尚未定义或不可访问,这将导致编译错误。
这对 POD 类型最有意义,因为它们的值在未初始化时是未定义的。
struct A
{
int t;
A() : { /* value of t undefined */ }
}
struct A
{
int t;
A() : t() { /* value of t is t's default value of 0 */ }
}