原文链接:http://www.codeceo.com/article/cpp-11-new-features-of-class.html
这是C++11新特性介绍的第六部分,涉及到Class的相关内容。
不想看toy code的读者可以直接拉到文章最后看这部分的总结。
sizeof
新标准中,sizeof可以直接用于获取Class::member的大小,而不用通过Class的实例。
class TestClass
{public: int member_i; char member_c;
};coutdefault constructor
新标准中,可以通过=default强制编译器生成一个默认constructor。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {} int member_i; char member_c;
};cout在上面的代码中,如果我们不提供默认constructor的话,无法通过TestClass tc定义一个实例。
delegate constructor
新标准中,可以在初始化列表中将一个constructor初始化的工作委托给另一个constructor。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {}
TestClass(const int i): TestClass(i, 0) { member_c = 'T';} int member_i; char member_c;
};coutallocator.construct
新标准中,allocator.construct可以使用任意的构造函数。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {}
TestClass(const int i): TestClass(i, 0) { member_c = 'T';} int member_i; char member_c;
};cout alloc;auto p = alloc.allocate(10);
alloc.construct(p, 10);coutmember_imember_ccopy constructor
新标准中,可以通过=default要求编译器合成默认的拷贝/赋值构造函数。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {}
TestClass(const int i): TestClass(i, 0) { member_c = 'T';}
TestClass(const TestClass&) = default;
TestClass& operator=(const TestClass&); int member_i; char member_c;
};cout同样,新标准中也允许用=delete禁止拷贝。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {}
TestClass(const int i): TestClass(i, 0) { member_c = 'T';}
TestClass(const TestClass&) = delete;
TestClass& operator=(const TestClass&); int member_i; char member_c;
};
TestClass& TestClass::operator=(const TestClass&) = default;coutoverride和final
新标准中提供了override和final两个关键字,用于标识子类对父类中虚函数的重写(override)或禁止重写(final)。
class TestClass
{public:
TestClass() = default;
TestClass(const int i, const char c): member_i(i), member_c(c) {}
TestClass(const int i): TestClass(i, 0) { member_c = 'T';}
TestClass(const TestClass&) = default;
TestClass& operator=(const TestClass&); virtual void print_msg() {coutprint_msg();SubTestClass stc(10);
TestClass tc6 = (TestClass)stc;
tc6.print_msg();如果标识了override的函数实际上没有重写父类中的函数,或者标识final的函数被子类重写,编译器都会报错。
通样的,标识为final的类也不允许作为父类被继承。
委托父类构造函数
新标准中,也支持子类在初始化列表中直接委托父类的构造函数完成初始化。
class SubTestClass final: public TestClass
{ public: using TestClass::TestClass;
SubTestClass(const int i): TestClass(i, 'S') {} void print_msg() override;
};cout多继承与默认constructor
多重继承的子类可以直接继承父类的构造函数,但是如果父类中有形参列表完全相同的构造函数,则会产生冲突,这时需要子类自己定义一个自己版本的构造函数。
class TestClass2
{public:
TestClass2() = default;
TestClass2(const int i) {}
};class MultiSubClass: public TestClass, public TestClass2
{public: using TestClass::TestClass; using TestClass2::TestClass2; // conflicts with version inherited from ‘TestClass’
MultiSubClass(const int i): TestClass(i) {}
MultiSubClass() = default;
};cout总结
sizeof可以直接用于获取Class::member的大小,而不用通过Class的实例。
可以通过=default强制编译器生成一个默认constructor。
可以在初始化列表中将一个constructor初始化的工作委托给另一个constructor,以及父类的constructor。
allocator.construct可以使用任意的构造函数。
可以通过=default要求编译器合成默认的拷贝/赋值构造函数,也可以通过=delete禁止拷贝。
新标准中提供了override和final两个关键字,用于标识子类对父类中虚函数的重写(override)或禁止重写(final),编译会对这两种情况进行检查。final还可以用于类的标识,表示禁止继承。
多重继承的子类可以直接继承父类的构造函数,但是如果父类中有形参列表完全相同的构造函数,则会产生冲突,这时需要子类自己定义一个自己版本的构造函数。
完整代码详见class.cpp