这里更深的一步就算深拷贝的应用是创建了新的空间是相对独立的。
这里要注意的是:1、接受一个参数的构造函数允许使用赋值语句隐式调用来初始化对象; 而explicit构造函数只能被显式调用。
2、因为explicit让函数变为显示,不能进行隐式转换,所以顺延到了short。
以下是对于explicit的测试代码
#include<iostream>
using namespace std;
class Test1
{
public:
Test1(int n)
{
num=n;
}//普通构造函数
private:
int num;
};
class Test2
{
public:
explicit Test2(int n)
{
num=n;
}//explicit(显式)构造函数
private:
int num;
};
int main()
{
Test1 t1=12;//隐式调用其构造函数,成功
Test2 t2=12;//编译错误,不能隐式调用其构造函数
Test2 t2(12);//显式调用成功
return 0;
}
需要注意的是
/在字符串里算的是转义符
所以
s t d \n 0 0 7 \1 \ 一共九个
还有要注意的是:
并且strlen()不计算字符串结尾符\0,sizeof()计算占用地址空间大小会算入在内
这里要注意的是结构体中,在C中typedef相当于划了一块给struct用的空间,
这样 使用的时候即可 struct(空间) + 名字 + 变量名
然后直接 变量名作为类 进行创建新的对象。
![在这里插入图片描述](https://img-blog.csdnimg.cn/2cad3a43383345c59aeb4d9f908bc7e2.png
实践代码