C++ Primer 笔记——拷贝控制】的更多相关文章

1.如果构造函数的第一个参数是自身类类型的引用,且任何额外参数都有默认值,则此构造函数是拷贝构造函数.拷贝构造函数的第一个参数必须是引用类型(否则会无限循环的调用拷贝构造函数). 2.如果没有为一个类定义拷贝构造函数,编译器会为我们定义一个合成拷贝构造函数.与合成默认构造函数不同,即使我们定义了其他的构造函数,编译器也会为我们合成一个拷贝构造函数. 3.合成的拷贝构造函数会将其参数的成员逐个拷贝到正在创建的对象中(除了static成员).对于类类型的成员,会使用其拷贝构造函数来拷贝,虽然我们不能…
十三.复制控制 1. 复制构造函数 类中的成员函数都默觉得inline类型.所以即使在类定义体内的函数声明显示定义为inline类型,在进行函数定义时也可以将inline进行省略. // 复制构造函数应该为常量引用类型,假设同意传值參数会造成无限循环调用从而导致内存溢出. CopyConstruct(const CopyConstruct& a){value = a.value;} 复制构造函数可用于初始化顺序容器中的元素,如vector<string> svec(5); 这样的方式使…
拷贝和移动构造函数定义了当用同类型的另一个对象初始化本对象时做什么.拷贝和移动赋值运算符定义了将一个对象赋予同类型的另一个对象时做什么.析构函数定义了当此类型对象销毁时做什么.我们称这些操作为拷贝控制操作. 如果一个构造函数的第一个参数是自身类类型的引用,且任何额外参数都有默认值,则此构造函数是拷贝构造函数. 拷贝构造函数的第一个参数必须是一个引用类型.虽然我们可以定义一个接受非const引用的拷贝构造函数,但此参数几乎总是一个const的引用. 拷贝构造函数在几种情况下都会被隐式地使用.因此,…
右值引用 所谓的右值引用就是必须将引用绑定到右值的引用,我们通过&&来绑定到右值而不是&, 右值引用只能绑定到即将销毁的对象.右值引用也是引用,因此右值引用也只不过是对象的别名而已.右值引用可以绑定到要求转换的表达式.字面常量或者返回右值的表达式,但是右值不能绑定到一个左值上. int i = 42; int &r = i; // 正确,r引用i int&& rr = i; // 错误,不能将右值引用绑定到左值 int &r2 = i * 42; /…
定义行为像值的类 行为像值的类,例如标准库容器和std::string这样的类一样,类似这样的类我们可以简单的实现一个这样的类HasPtr. 在实现之前,我们需要: 定义一个拷贝构造函数,完成string的拷贝,而不是指向string的指针的拷贝: 定义一个拷贝赋值运算符,释放当前的string,并从右侧拷贝新的string. 定义一个析构函数来释放string class HasPtr { public: HasPtr(const std::string& s = std::string())…
拷贝构造函数 一个构造函数的第一个参数是自身类类型的引用,额外的参数(如果有)都有默认值,那么这个构造函数是拷贝构造函数.拷贝构造函数的第一个参数必须是一个引用类型. 合成的拷贝构造函数   在我们没有定义自己的拷贝构造函数,编译器会为我们合成一个.但是对于有些类来说,合成拷贝构造函数用来阻止我们拷贝该类类型的对象.而一般情况,合成拷贝构造函数会将其参数的成员逐个拷贝到正在创建的对象中,编译器依次将每个非static成员拷贝到正在创建的对象中. 每个成员的类型决定了它如何拷贝:对类类型的成员,…
拷贝控制和资源管理 • 类的行为像一个值.意味着它应该有自己的状态,当我们拷贝一个像值得对象时,副本和原对象是完全独立的,改变副本不会对原对象有任何影响. • 行为像指针的类则共享状态.当我们拷贝一个这种类的对象时,副本和原对象使用相同的底层数据,改变副本也会改变原对象. 13.2节练习 #include<iostream> #include<string> using namespace std; class HasPtr { public: HasPtr() {} HasPtr…
拷贝控制.赋值和销毁 如果一个构造函数的第一个参数是自身类的引用,且额外的参数都有默认值,则此构造函数是拷贝控制函数(拷贝构造函数不应该是explicit的). 如果我们没有为一个类定义拷贝构造函数,编译器会为我们定义一个,与合成默认构造函数不同, 即使我们定义了其他构造函数,编译器也会为我们合成一个拷贝构造函数. class Sales_data { public: Sales_data(const Sales_data&); private: string bookNo; ; double…
合成拷贝控制与继承 #include <iostream> using namespace std; class Base { public: Base() { cout << "Base contruction" << endl; } virtual ~Base() { cout << "Base deconstruction" << endl; } }; class Derived : public B…
拷贝控制示例 #include<iostream> #include<string> #include<set> #include<vector> using namespace std; class Folder; class Message { friend void swap(Message&, Message&); friend class Folder; public: explicit Message(const string &…