標籤:3.1 結果 def 測試 span 編譯 fine void 技術
C++拷貝建構函式
在定義任何C++類時,拷貝空置操作都是必要部分,類需要控制拷貝、賦值和銷毀對象時發生的行為。拷貝建構函式的用途:當建立了一個新對象時,可以用另一個對象的資料初始化這個建立的對象。
1、預設拷貝建構函式
如果在程式中我們沒有顯示定義拷貝建構函式,則C++會為每個類隱式地提供一個預設的拷貝建構函式,不過就算我們顯示定義了拷貝建構函式,程式同樣也會自己合成一個預設的建構函式。預設的建構函式簡單地將參數對象的每個資料域複製給對象中相應的副本。拷貝建構函式和賦值運算子是相似的,它們把一個對象的值賦給另一個對象,但兩者不一樣!使用拷貝建構函式將建立新的對象,而使用賦值運算子則不會建立新對象。比如下面的例子:
//circle.h#ifndef _CIRCLE_H_#define _CIRCLE_H_class Circle{ public: Circle(); Circle(double radius); ~Circle(); void setRadius(double radius); double getRadius(); double getArea(); private: double radius;};#endif //circle.h
#include "circle.h"#include <iostream>Circle::Circle(){ radius = 1;}Circle::Circle(double radius){ this->radius = radius;}void Circle::setRadius(double radius){ this->radius = radius;}double Circle::getRadius(){ return radius;}double Circle::getArea(){ return 3.14159 * radius * radius;}Circle::~Circle(){}
測試函數main:
#include <iostream>#include "circle.h"using namespace std;int main(){ Circle c1(99); Circle c2(c1); //這裡沒有顯示定義拷貝建構函式,編譯器就隱式調用了一個 cout << "The c1 radius is " << c1.getRadius() << " and area is " << c1.getArea() << endl; cout << "The c2 radius is " << c2.getRadius() << " and area is " << c2.getArea() << endl; return 0;}
運行結果如下(我們發現兩個Circle對象c1和c2資料域都是一樣的):
2、“深拷貝”和“淺拷貝”
“淺拷貝”指的是拷貝指標的地址,不拷貝該指標指向的記憶體內容;“深拷貝”指的是拷貝指標指向的記憶體內容,不拷貝指標本身。程式隱式產生的拷貝建構函式和賦值運算子進行對象複製採用的是一種所謂的“淺拷貝”。
繼續更新。。。
C++拷貝建構函式專題