亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++ 拷貝構造

發布時間:2020-07-11 19:59:14 來源:網絡 閱讀:668 作者:Aonaufly 欄目:移動開發

在C++存在拷貝構造函數,拷貝構造函數與不同構造函數形成重載(這一點很重要),這就意味著(要么class入口為普通構造函數,要么為拷貝構造函數,不可能2個都會執行的)。好了 , 下面可是今天的StudyingC++ 拷貝構造

一 , 實際上C++類中有一個默認的拷貝構造,它的作用是將此類中非static成員逐一copy。現在先不管默認的Copy構造,我先先重載一下Copy構造:

#include <iostream>
using namespace std;
class copyC
{
public:
    int a;
    copyC()
    {
        this->a = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        this->a = b.a;
    }
};
int main()
{
    return 0;
}

拷貝函數 : copyC( const copyC &b ) ,  里面的語句:this->a = b.a;實現的效果其實是和默認拷貝構造是一樣的。


話鋒先轉一下,談下拷貝函數的觸發機制(在什么條件下會調用)

①:用一個對象為另一個對象初始化

1->

#include <iostream>
using namespace std;
class copyC
{
public:
    int a;
    copyC()
    {
        this->a = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
};
int main()
{
    copyC str;
    copyC new1(str);
    cout << new1.a << endl;
    return 0;
}

結果:

C++ 拷貝構造

關鍵:

    copyC str;
    copyC new1(str);


2->

    copyC str;
    copyC new1 = str;

3->

    copyC str;
    copyC new1 = copyC(str);

4->

#include <iostream>
using namespace std;
class copyC
{
public:
    int a;
    copyC()
    {
        this->a = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
};
int main()
{
    copyC str;
    copyC *new1 = new copyC(str);
    cout << new1->a << endl;
    delete new1;
    return 0;
}

結果一樣:

C++ 拷貝構造

小結 :

上面的1,2,3,4中情況都會調用拷貝構造。

②:當對象生成對象副本時

1->傳遞對象

#include <iostream>
using namespace std;
class copyC
{
public:
    int a;
    copyC()
    {
        this->a = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
    static void copyFun( copyC b )
    {
    }
};
int main()
{
    copyC str;
    copyC::copyFun(str);
    return 0;
}

結果:

C++ 拷貝構造

2->返回對象

#include <iostream>
using namespace std;
class copyC
{
public:
    int a;
    copyC()
    {
        this->a = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
    static void copyFun( copyC b )
    {
    }
    copyC copyFun()
    {
        copyC a;
        return a;
    }
};
int main()
{
    copyC str;
    copyC new1 = str.copyFun();
    new1.a = 4;
    cout << str.a << endl;
    cout << new1.a << endl;
    return 0;
}

結果有點詭異 , 但是理論是正確的:

C++ 拷貝構造

new1確實拷貝成功 , 但是“執行了構造函數”好像沒打印出來,這和IDE有關嗎 ? 各位讀者





好了 , 現在正式講講拷貝構造的作用:

默認拷貝為淺拷貝,淺拷貝在有*(指針)成員的時候會報錯:

#include <iostream>
using namespace std;
class copyC
{
public:
    int *a;
    copyC()
    {
        this->a = new int[2];
        *(a) = 1;
        *(a+1) = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
    ~copyC()
    {
        delete[] a;
    }
};
int main()
{
    {
        copyC str;
        cout << str.a[0] << "  " << str.a[1] << endl;
        copyC new1 = str;
        cout << new1.a[0] << "  " << new1.a[1] << endl;
    }
    return 0;
}

出現結果:

C++ 拷貝構造

正確的結果出來了 , 但是bug也出來了 。

對于bug的解釋:

無論是str還是new1對象,他們的成員指針a都是1個對象(不是2個相同的對象),在內存中的一個對象,那么一個指針是不能釋放2次的。

一,如下:

#include <iostream>
using namespace std;
class copyC
{
public:
    int *a;
    copyC()
    {
        this->a = new int[2];
        *(a) = 1;
        *(a+1) = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        this->a = b.a;
    }
    ~copyC()
    {
        if( a != NULL )
            delete[] a;
    }
};
int main()
{
    {
        copyC str;
        cout << str.a[0] << "  " << str.a[1] << endl;
        copyC new1 = str;
        cout << new1.a[0] << "  " << new1.a[1] << endl;
    }
    return 0;
}

使用這種方案的時候一定要注意 : a(指針)雖然在2個對象里面(一個是copy的對象)但是a確實是1個對象。


二,重載拷貝構造(這個可以將a(指針)在確實的拷貝一份,這就是深拷貝了)

#include <iostream>
using namespace std;
class copyC
{
public:
    int *a;
    copyC()
    {
        this->a = new int[2];
        *(a) = 1;
        *(a+1) = 2;
    }
    //拷貝構造函數
    copyC( const copyC &b )
    {
        //執行拷貝構造函數
        cout << "執行了構造函數" << endl;
        //this->a = b.a;//這是淺拷貝方案
        this->a = new int[2];
        memcpy(this->a , b.a , 2*sizeof(int));
    }
    ~copyC()
    {
        delete[] a;
    }
};
int main()
{
    system("color 2B");
    {
        copyC str;
        copyC new1 = str;
        cout << new1.a[0] << "  " << new1.a[1] << endl;
        new1.a[0] = 3;
        new1.a[1] = 4;
        cout << "--------------------------------------------" << endl;
        cout << new1.a[0] << "  " << new1.a[1] << endl;
        cout << str.a[0] << "  " << str.a[1] << endl;
    }
    return 0;
}

運行結果:

C++ 拷貝構造

str 中的成員a 和 new1中的成員a ,確實是2個對象哈。。。。。。

好了 , 本篇結束。。。。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

石家庄市| 桐梓县| 凤庆县| 南乐县| 瑞金市| 昌江| 甘谷县| 石狮市| 玛纳斯县| 潞西市| 乐山市| 金门县| 龙里县| 哈尔滨市| 红桥区| 新野县| 云南省| 奈曼旗| 古蔺县| 东丽区| 禄劝| 顺平县| 蛟河市| 新宁县| 隆昌县| 德化县| 五河县| 宁陵县| 卓资县| 巴青县| 上杭县| 秦皇岛市| 托克逊县| 屯门区| 彭泽县| 邯郸市| 隆安县| 淅川县| 澎湖县| 拜泉县| 临颍县|