栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C++ 11 新特性之Class

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C++ 11 新特性之Class

原文链接: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;
};cout<<"test sizeof class member:n";cout<default 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<<"test =default class construct:n";
TestClass tc; // may cause error if no default construct.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;
};cout<<"test delegating constructor:n";TestClass tc2(2);cout<allocator.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<<"test allocator:n";
allocator alloc;auto p = alloc.allocate(10);
alloc.construct(p, 10);cout<member_i<<'t'<member_c<copy 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<<"test =default class copy construct:n";TestClass tc3(tc2);
TestClass tc4 = tc2;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;cout<<"test =delete class copy construct:n";//TestClass tc5(tc2); // error: use of deleted function ‘TestClass::TestClass(const TestClass&)’//cout<override和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() {cout<print_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<<"test inherit base class contructor:n";SubTestClass stc2(1024, 'H');
stc2.print_msg();
多继承与默认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<<"test multi inherit constructor:n";MultiSubClass mtc(1024);
mtc.print_msg();return 0;
总结
  1. sizeof可以直接用于获取Class::member的大小,而不用通过Class的实例。

  2. 可以通过=default强制编译器生成一个默认constructor。

  3. 可以在初始化列表中将一个constructor初始化的工作委托给另一个constructor,以及父类的constructor。

  4. allocator.construct可以使用任意的构造函数。

  5. 可以通过=default要求编译器合成默认的拷贝/赋值构造函数,也可以通过=delete禁止拷贝。

  6. 新标准中提供了override和final两个关键字,用于标识子类对父类中虚函数的重写(override)或禁止重写(final),编译会对这两种情况进行检查。final还可以用于类的标识,表示禁止继承。

  7. 多重继承的子类可以直接继承父类的构造函数,但是如果父类中有形参列表完全相同的构造函数,则会产生冲突,这时需要子类自己定义一个自己版本的构造函数。

完整代码详见class.cpp


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/232859.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号