欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++編程語言中賦值運算符重載函數(shù)(operator=)的使用

 更新時間:2022年06月10日 10:02:25   作者:liitdar  
本文主要介紹了C++編程語言中賦值運算符重載函數(shù)(operator=)介紹,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

本文主要介紹 C++ 編程語言中賦值運算符重載函數(shù)(operator=)的相關(guān)知識,同時通過示例代碼介紹賦值運算符重載函數(shù)的使用方法。

1 概述

1.1 Why

首先介紹為什么要對賦值運算符“=”進行重載。某些情況下,當(dāng)我們編寫一個類的時候,并不需要為該類重載“=”運算符,因為編譯系統(tǒng)為每個類提供了默認(rèn)的賦值運算符“=”,使用這個默認(rèn)的賦值運算符操作類對象時,該運算符會把這個類的所有數(shù)據(jù)成員都進行一次賦值操作。例如有如下類:

class A
{
public:
    int a;
    int b;
    int c;
};

對這個類的對象進行賦值時,使用默認(rèn)的賦值運算符是沒有問題的。

示例代碼內(nèi)容如下:

#include <iostream>
 
using namespace std;
 
class ClassA
{
public:
    int a;
    int b;
    int c;
};
 
int main()
{
    ClassA obj1;
    obj1.a = 1;
    obj1.b = 2;
    obj1.c = 3;
 
    ClassA obj2;
    obj2 = obj1;
 
    cout << "obj2.a is: " << obj2.a << endl;
 
    return 0;
}
 

編譯并執(zhí)行上述代碼,結(jié)果如下:

通過上述結(jié)果能夠知道:通過使用系統(tǒng)默認(rèn)的賦值運算符“=”,可以讓對象 obj2 中的所有數(shù)據(jù)成員的值與對象 obj1 相同。這種情況下,編譯系統(tǒng)提供的默認(rèn)賦值運算符可以正常使用。

但是,在下面的示例中,使用編譯系統(tǒng)提供的默認(rèn)賦值運算符,就會出現(xiàn)問題了。

示例代碼內(nèi)容如下:

#include <iostream>
#include <string.h>
 
using namespace std;
 
class ClassA
{
public:
    ClassA()
    {
    
    }
 
    ClassA(const char* pszInputStr)
    {
        pszTestStr = new char[strlen(pszInputStr) + 1];
        strncpy(pszTestStr, pszInputStr, strlen(pszInputStr) + 1);
    }
    virtual ~ClassA()
    {
        delete pszTestStr;
    }
public:
    char* pszTestStr;
};
 
int main()
{
    ClassA obj1("liitdar");
 
    ClassA obj2;
    obj2 = obj1;
 
    cout << "obj2.pszTestStr is: " << obj2.pszTestStr << endl;
    cout << "addr(obj1.pszTestStr) is: " << &obj1.pszTestStr << endl;
    cout << "addr(obj2.pszTestStr) is: " << &obj2.pszTestStr << endl;
 
    return 0;
}

編譯并運行上述代碼,結(jié)果如下:

上述錯誤信息表明:當(dāng)對象 obj1 和 obj2 進行析構(gòu)時,由于重復(fù)釋放了同一塊內(nèi)存空間,導(dǎo)致程序崩潰報錯。在這種情況下,就需要我們重載賦值運算符“=”了。

2 示例代碼

2.1 示例代碼1

我們修改一下前面出錯的示例代碼,編寫一個包含賦值運算符重載函數(shù)的類,修改后的代碼內(nèi)容如下:

#include <iostream>
#include <string.h>
 
using namespace std;
 
class ClassA
{
public:
    ClassA()
    {
    
    }
    ClassA(const char* pszInputStr)
    {
        pszTestStr = new char[strlen(pszInputStr) + 1];
        strncpy(pszTestStr, pszInputStr, strlen(pszInputStr) + 1);
    }
    virtual ~ClassA()
    {
        delete pszTestStr;
    }
    // 賦值運算符重載函數(shù)
    ClassA& operator=(const ClassA& cls)
    {
        // 避免自賦值
        if (this != &cls)
        {
            // 避免內(nèi)存泄露
            if (pszTestStr != NULL)
            {
                delete pszTestStr;
                pszTestStr = NULL;
            }
 
            pszTestStr = new char[strlen(cls.pszTestStr) + 1];
            strncpy(pszTestStr, cls.pszTestStr, strlen(cls.pszTestStr) + 1);
        }
        
        return *this;
    }
    
public:
    char* pszTestStr;
};
 
int main()
{
    ClassA obj1("liitdar");
 
    ClassA obj2;
    obj2 = obj1;
 
    cout << "obj2.pszTestStr is: " << obj2.pszTestStr << endl;
    cout << "addr(obj1.pszTestStr) is: " << &obj1.pszTestStr << endl;
    cout << "addr(obj2.pszTestStr) is: " << &obj2.pszTestStr << endl;
 
    return 0;
}
 

編譯并運行上述代碼,結(jié)果如下:

通過上述結(jié)果能夠看到,利用賦值運算符重載函數(shù),解決了對象賦值時,析構(gòu)函數(shù)多次釋放同一塊內(nèi)存空間的問題。

對于上述代碼,有以下幾點需要說明:

當(dāng)為一個類的對象賦值(可以用本類對象為其賦值,也可以用其它類型的值為其賦值)時,該對象(如本例的 obj2)會調(diào)用該類的賦值運算符重載函數(shù),進行具體的賦值操作。如上述代碼中的“obj2 = obj1;”語句,用 obj1 為 obj2 賦值,則會由 obj2 調(diào)用 ClassA 類的賦值運算符重載函數(shù);

下方語句和語句“ClassA obj2 = obj1;”在調(diào)用函數(shù)上是有區(qū)別的:前者第一句是對象 obj2 的聲明及定義,調(diào)用類 ClassA 的無參構(gòu)造函數(shù),所以“obj2 = obj1;”一句是在對象 obj2 已經(jīng)存在的情況下,用 obj1 來為 obj2 賦值,調(diào)用的是賦值運算符重載函數(shù);而后者,是用 obj1 來初始化 obj2,調(diào)用的是拷貝構(gòu)造函數(shù)??截悩?gòu)造函數(shù)的語句樣式為“ClassA(const ClassA& cls)”,關(guān)于拷貝構(gòu)造函數(shù)的詳細(xì)內(nèi)容,請參考相關(guān)內(nèi)容,此處不展開介紹;

ClassA obj2;
obj2 = obj1;

當(dāng)程序沒有顯式地提供一個以“本類或本類的引用”為參數(shù)的賦值運算符重載函數(shù)時,編譯器會自動生成一個默認(rèn)的賦值運算符重載函數(shù)(即默認(rèn)賦值運算符)。

2.2 示例代碼2

示例代碼內(nèi)容如下:

#include<iostream>
#include<string>
 
using namespace std;
 
class Data
{
private:
    int data;
    
public:
    // 構(gòu)造函數(shù)
    Data()
    {
    };
    // 構(gòu)造函數(shù)
    Data(int _data):data(_data)
    {
        cout << "This is constructor" << endl;
    }
    // 賦值運算符重載函數(shù)
    Data& operator=(const int _data)
    {
        cout << "This is operator=(int _data)" << endl;
        data = _data;
        
        return *this;
    }
};
 
int main()
{
    // 調(diào)用構(gòu)造函數(shù)
    Data data1(1);
    Data data2, data3;
    // 調(diào)用賦值運算符重載函數(shù)
    data2 = 1;
    // 調(diào)用默認(rèn)的賦值運算符重載函數(shù)
    data3 = data2;
    
    return 0;
}

編譯并執(zhí)行上述代碼,結(jié)果如下:

上述結(jié)果表明:“data2 = 1;”語句調(diào)用了我們提供的以 int 型參數(shù)(而非本類或本類的引用)為形參的賦值運算符重載函數(shù);而“data3 = data2;”的成功執(zhí)行,說明該語句調(diào)用了編譯器提供的默認(rèn)的賦值運算符重載函數(shù)。

如果將上述代碼中賦值運算符重載函數(shù)去掉,重新編譯執(zhí)行,結(jié)果如下:

上述結(jié)果說明,當(dāng)用一個非類 A 的值(如上面的 int 類型值)為類 A 的對象賦值時:

  • 如果檢測到構(gòu)造函數(shù)和賦值運算符重載函數(shù)同時存在,則會優(yōu)先調(diào)用賦值運算符重載函數(shù);
  • 如果只檢測到構(gòu)造函數(shù),就會調(diào)用構(gòu)造函數(shù)。

3 總結(jié)

綜合本文內(nèi)容,可以知道針對以下情況,需要顯式地提供賦值運算符重載函數(shù)(即自定義賦值運算符重載函數(shù)):

  • 用非類 A 類型的值為類 A 的對象賦值時(當(dāng)然,這種情況下我們也可以不提供相應(yīng)的賦值運算符重載函數(shù),而只提供相應(yīng)的構(gòu)造函數(shù),如更改后的示例代碼2);
  • 用類 A 類型的值為類 A 的對象賦值,且類 A 的數(shù)據(jù)成員中含有指針的情況下,必須顯式提供賦值運算符重載函數(shù)(如示例代碼1)。

到此這篇關(guān)于C++編程語言中賦值運算符重載函數(shù)(operator=)介紹的文章就介紹到這了,更多相關(guān)C++ 賦值運算符重載函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++ 單鏈表的基本操作(詳解)

    C++ 單鏈表的基本操作(詳解)

    下面小編就為大家?guī)硪黄狢++ 單鏈表的基本操作(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C語言的sleep、usleep、nanosleep等休眠函數(shù)的使用

    C語言的sleep、usleep、nanosleep等休眠函數(shù)的使用

    本文主要介紹了C語言的sleep、usleep、nanosleep等休眠函數(shù)的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • opencv利用鼠標(biāo)滑動畫出多彩的形狀

    opencv利用鼠標(biāo)滑動畫出多彩的形狀

    這篇文章主要為大家詳細(xì)介紹了opencv利用鼠標(biāo)滑動畫出多彩的形狀,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • 實例講解C++編程中的虛函數(shù)與虛基類

    實例講解C++編程中的虛函數(shù)與虛基類

    這篇文章主要介紹了C++編程中的虛函數(shù)與虛基類的實例講解,虛函數(shù)與虛基類的使用是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2016-02-02
  • 在C語言編程中使用變量的基礎(chǔ)教程

    在C語言編程中使用變量的基礎(chǔ)教程

    這篇文章主要介紹了在C語言編程中使用變量的基礎(chǔ)教程,特別需要注意C語言中的指針變量,需要的朋友可以參考下
    2016-02-02
  • C語言?超詳細(xì)講解鏈接器

    C語言?超詳細(xì)講解鏈接器

    在C語言中,一個重要的思想就是分別編譯,即若干個源程序能夠在不一樣的時候單獨進行編譯,而后在恰當(dāng)?shù)臅r候整合到一塊兒??墒擎溄悠魍ǔJ桥cC編譯器分離的,鏈接器如何作到把若干個C源程序合并成一個總體呢,我們一起來看看
    2022-03-03
  • C++ LARGE_INTEGER解析與使用案例詳解

    C++ LARGE_INTEGER解析與使用案例詳解

    這篇文章主要介紹了C++ LARGE_INTEGER解析與使用案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++ 字符串的反轉(zhuǎn)五種方法實例

    C++ 字符串的反轉(zhuǎn)五種方法實例

    通過不同的方法,實現(xiàn)對所輸入字符串的反轉(zhuǎn),有需要的朋友可以參考一下
    2013-09-09
  • C++中的繼承模式深入詳解

    C++中的繼承模式深入詳解

    這篇文章主要介紹了C++中的繼承模式深入詳解。繼承是OOP設(shè)計中的重要概念。在C++語言中,派生類繼承基類有三種繼承方式:私有繼承(private)、保護繼承(protected)和公有繼承(public)。
    2021-03-03
  • C++17新特性個人總結(jié)

    C++17新特性個人總結(jié)

    這篇文章主要介紹了C++17新特性個人總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07

最新評論