What does a colon following a C++ constructor name do?
This question already has an answer here:
This is an initialization list , and is part of the constructor's implementation.
The constructor's signature is:
MyClass();
This means that the constructor can be called with no parameters. This makes it a default constructor, ie, one which will be called by default when you write MyClass someObject;
.
The part : m_classID(-1), m_userdata(0)
is called initialization list . It is a way to initialize some fields of your object (all of them, if you want) with values of your choice, instead of leaving them as undefined.
After executing the initialization list, the constructor body (which happens to be empty in your example) is executed. Inside it you could do more assignments, but once you have entered it all the fields have already been initialized - either to random, unspecified values, or to the ones you chose in your initialization list. This means the assignments you do in the constructor body will not be initializations, but changes of values.
It is an initialization list.
By the time you get in the body of the constructor, all fields have already been constructed; if they have default constructors, those were already called. Now, if you assign a value to them in the body of the constructor, you are calling the copy assignment operator, which may mean releasing and reacquiring resources (eg memory) if the object has any.
So in the case of primitive types like int, there's no advantage compared to assigning them in the body of the constructor. In the case of objects that have a constructor, it is a performance optimization because it avoids going through two object initializations instead of one.
An initialization list is necessary if one of the fields is a reference because a reference can never be null, not even in the brief time between object construction and the body of the constructor. The following raises error C2758: 'MyClass::member_' : must be initialized in constructor base/member initializer list
class MyClass {
public :
MyClass(std::string& arg) {
member_ = arg;
}
std::string& member_;
};
The only correct way is:
class MyClass {
public :
MyClass(std::string& arg)
: member_(arg)
{
}
std::string& member_;
};
It denotes the beginning of an initialiser list, which is for initialising member variables of your object.
As to: MyClass(m_classID = -1, m_userdata = 0);
That declares a constructor which can take arguments (so I could create a MyClass
using MyClass m = MyClass(3, 4)
, which would result in m_classID
being 3, and m_userdata
being 4). If I were to pass no arguments to the MyClass
constructor, it would result in an equivalent object being created to the version with the initialiser list.
上一篇: 未定义,未指定和实现