委托构造函数详解,小白也可以看懂

什么是委托构造函数

当我还不知道这个东西的时候,看到名字,顾名思义,我理解为委托其他构造函数帮忙构造。

这和定义也是相近的!

C++11 引入了委托构造的概念,这使得构造函数可以在同一个类中一个构造函数调用另一个构造函 数,从而达到简化代码的目的

为什么要有委托构造函数?

避免你有多个参数表不同但是逻辑相近(或者有公共部分)的构造函数的时候,一个逻辑写好几遍造成代码重复。

这里要更好的理解,需要将一个故事

如图1, 班主任要求A、B、C三位同学完成将各自资料送交办公室任务.(C++中初始化成员) ,虽然三位同学手中的资料不同(各成员列表), 但是需要完成的操作是相同的(初始化), 都是送往办公室。按照C++98的做法, 则需要A、B、C三位同学各自重复相同操作。这显示是不必要的. 对于C++11, 完全可以将这个工作委托给一个同学(充当目标构造函数, 后面会专门将到)去间接完成, 这样便省去了大量的重复性劳动。

在这里插入图片描述

委托构造函数也是构造函数, 因此, 构造函数的特性都适合委托构造函数, 比如: 没有返回值, 可以有一个或多个参数, 有函数体等。委托构造函数也有一个成员初始值列表和函数体。 在委托构造函数内, 成员初始值列表的唯一入口便是类名本身。然后紧接着是以圆括号围起来的参数列表, 这些参数列表必须与类中的另外一个构造函数相匹配。

代码讲解

#include"entrusted_construction.h"


/*******************************************************************************************************
//委托构造函数
C++11 引入了委托构造的概念,这使得构造函数可以在同一个类中一个构造函数调用另一个构造函
数,从而达到简化代码的目的。
*******************************************************************************************************/

#include <iostream>
class Base 
{
public:
	int value1;
	int value2;
	Base()    //目标构造函数
	{
		value1 = 1;
	}
	Base(int value) : Base()  //委托构造函数
	{ // 委托 Base() 构造函数
		value2 = value;
	}
};
void EntrustedConstruction()
{
	Base b(2);  //首先调用Base(int value) : Base() 毫无疑问
    //然后会走到base()中,先给value1复制,然后走到Base(int value) : Base() ,给value2赋值
	std::cout << b.value1 << std::endl;
	std::cout << b.value2 << std::endl;
}

运行结果:

在这里插入图片描述

注意事项

1.不能出现”委托环“

所谓 委托环(delegation cycle) 是指某类中有一个若多个委派构造函数, 然后在这些若干个的委派构造函数中, 某些目标构造函数可能同时是委派构造函数。 这样一来, 委派构造函数形成了一个链状结构(如链表的首尾相连情况.), 这就是所谓的“委托环”。

2.构造函数不能同时“委派”和使用初始化列表

参考链接

聊一聊,什么是C++11新特性之“委托构造函数”

  • 19
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的构造函数是用于创建对象的特殊函数。它们与普通函数的不同之处在于,它们使用“new”关键字来调用,从而创建一个新的对象。构造函数通常用于定义类(class),并在创建新对象时初始化类的属性和方法。下面是一些关于构造函数的详细说明: 1. 构造函数的命名通常以大写字母开头,以便与其他函数区分开来。 2. 构造函数内部使用“this”关键字来引用新创建的对象。 3. 构造函数使用“prototype”属性来定义对象的方法。 4. 构造函数可以接受参数,这些参数可以用来初始化对象的属性。 5. 构造函数可以使用“instanceof”操作符来确定一个对象是否为特定类的实例。 下面是一个简单的构造函数示例,它定义了一个名为“Person”的类,该类具有“name”和“age”属性: ```javascript function Person(name, age) { this.name = name; this.age = age; } Person.prototype.sayHello = function() { console.log("Hello, my name is " + this.name + " and I am " + this.age + " years old."); } var john = new Person("John", 30); john.sayHello(); // 输出:Hello, my name is John and I am 30 years old. ``` 在这个示例中,“Person”函数是一个构造函数,在创建新对象时使用“new”关键字来调用。该函数使用“this”关键字来引用新创建的对象,并将“name”和“age”属性分配给该对象。使用“prototype”属性,我们为“Person”类定义了一个“sayHello”方法,可以用来打印对象的属性。最后,我们创建了一个名为“john”的新对象,并调用了它的“sayHello”方法,输出了对象的属性。 希望这个简单的示例可以帮助你更好地理解构造函数的概念。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值