28)拷貝建構函式

2022-04-02 13:43:08 字數 1812 閱讀 8605

1)由已存在的物件,建立新物件,也就是說新物件,不由構造器來構造,而是由拷貝構造器來完成。

2)拷貝構造器的格式:

1

class類名2

78 }

3)拷貝建構函式,為啥是唯讀的,因為我僅僅是用它來初始化自己,我不會改變那個物件的值,所以加乙個const保護起來

4)

1 #include2

using

namespace

std;34

class

test

512 test(int x,int

y)13

18void

print_t()

1922//拷貝建構函式,為啥是唯讀的,因為我僅僅是用它來初始化自己,我不會改變那個物件的值,所以加乙個const保護起來23 test(const test &another)

2428

private:29

intm_x;

30int

m_y;

31};

3233

intmain()

34

5)即使我不寫那個拷貝建構函式  其實用另一種方式初始化 也是可以的

1 #include2

using

namespace

std;34

class

test

512 test(int x,int

y)13

18void

print_t()

1922

2324

/*test(const test &another)

25*/

2930

private:31

intm_x;

32int

m_y;

33};

3435

intmain()

36

6)但是,如果我的**這樣寫,就是呼叫的是test的拷貝建構函式

1 #include2

using

namespace

std;34

class

test

512 test(int x,int

y)13

18void

print_t()

1922

private:23

intm_x;

24int

m_y;

25};

2627

intmain()

28

調的是  

1

void

operator=(const test &another)

2

8) 當我乙個函式返回乙個物件,如果在函式外部沒有任何變數去接收它,這個物件將不會再被使用,(找不到),編譯會直接將這個匿名物件**掉,而不是等待函式執行完畢再**。

這個func2()返回乙個物件,因為 return  test1,(其實僅僅test1的值,所以  這個函式返回了,就作為乙個匿名物件出現)

這樣,那個匿名物件有了名字,就不會被**了,然後  就不會呼叫析構了。

不懂  可以看  台式電腦的:

10)

拷貝建構函式,預設拷貝建構函式

拷貝建構函式,預設拷貝建構函式 1.c 的預設拷貝建構函式,從深度拷貝和淺拷貝說起 c 類的預設拷貝建構函式的弊端 c 類的中有兩個特殊的建構函式,1 無參建構函式,2 拷貝建構函式。它們的特殊之處在於 1 當類中沒有定義任何建構函式時,編譯器會預設提供乙個無參建構函式且其函式體為空 2 當類中沒有...

建構函式 拷貝建構函式

建構函式可以分為三類 1 不帶引數的建構函式 在函式體中對資料成員賦初值,這種方式使該類的每乙個物件都得到同一組初值 2 帶引數的建構函式 如果使用者希望對不同的物件賦不同的初值,可以採用帶引數的建構函式。在呼叫不同物件的建構函式時從外面將不同的資料傳遞給建構函式,以實現初始化 3 複製建構函式 建...

建構函式 拷貝建構函式

person person 引用就是指標常量 所以person p person const p,引用所以一旦初始化指向某個位址,就不能在改變了。為什麼前面還要加const,因為拷貝建構函式的目的就是將乙個物件的所有屬性拷貝到另外乙個物件,這個物件的屬性不變,加上const 相當於 const pe...