亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳談C++何時(shí)需要定義賦值/復(fù)制構(gòu)造函數(shù)

 更新時(shí)間:2017年01月08日 07:39:54   投稿:jingxian  
下面小編就為大家?guī)硪黄斦凜++何時(shí)需要定義賦值/復(fù)制構(gòu)造函數(shù)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

繼承和動(dòng)態(tài)內(nèi)存分配

假設(shè)基類使用了動(dòng)態(tài)內(nèi)存分配,而且定義了析構(gòu)函數(shù)、復(fù)制構(gòu)造函數(shù)和賦值函數(shù),但是在派生類中沒有使用動(dòng)態(tài)內(nèi)存分配,那么在派生類中不需要顯示定義析構(gòu)函數(shù)、復(fù)制構(gòu)造函數(shù)和賦值函數(shù)。

當(dāng)基類和派生類采用動(dòng)態(tài)內(nèi)存分配時(shí),派生類的析構(gòu)函數(shù)、復(fù)制構(gòu)造函數(shù)、賦值運(yùn)算符都必須使用相應(yīng)的基類方法來處理基類元素。這種要求是通過三種不同的方式來滿足的。對(duì)于析構(gòu)函數(shù)。這是自動(dòng)完成的,也就是說在派生類的析構(gòu)函數(shù)中無需顯示調(diào)用基類的析構(gòu)函數(shù)。對(duì)于構(gòu)造函數(shù),這是通過在初始化成員列表中調(diào)用基類的復(fù)制構(gòu)造函數(shù)來完成的,如果不這樣做,將自動(dòng)調(diào)用基類的默認(rèn)構(gòu)造函數(shù),對(duì)于賦值運(yùn)算符,這是通過使用域解析運(yùn)算符顯示地調(diào)用基類的賦值運(yùn)算符來完成的。

編譯器生成的成員函數(shù)

1、  默認(rèn)構(gòu)造函數(shù)

默認(rèn)構(gòu)造哈數(shù)要么沒有參數(shù),要么所有的參數(shù)都有默認(rèn)值。如果沒有定義任何構(gòu)造函數(shù),編譯器將定義構(gòu)造函數(shù)。另外,如果派生類構(gòu)造函數(shù)的成員初始化列表中沒有顯示調(diào)用基類構(gòu)造函數(shù),則編譯器將使用基類的默認(rèn)構(gòu)造函數(shù)來構(gòu)造派生類對(duì)象的基類部分。在這種情況下,如果基類沒有構(gòu)造函數(shù),將導(dǎo)致編譯階段錯(cuò)誤。如果定義了某種構(gòu)造函數(shù),編譯器將不會(huì)定義默認(rèn)構(gòu)造函數(shù)。在這種情況下,如果需要默認(rèn)構(gòu)造函數(shù),則必須自己提供。(最好的建議就是,一旦自己定義了構(gòu)造函數(shù),那么最好再定義一個(gè)默認(rèn)的構(gòu)造函數(shù),這樣在別的子類中調(diào)用也非常的方便)

提供構(gòu)造函數(shù)的動(dòng)機(jī)之一是確保對(duì)象總能被正確地初始化。另外,如果類包含指針成員,則必須初始化這些成員。因此,最好提供一個(gè)顯示默認(rèn)構(gòu)造函數(shù),將所有的類數(shù)據(jù)成員初始化為合理的值。

2、  復(fù)制構(gòu)造函數(shù)

復(fù)制構(gòu)造函數(shù)接受其所屬類的對(duì)象作為參數(shù)。在下述情況下,將使用復(fù)制構(gòu)造函數(shù)

將新對(duì)象初始化為一個(gè)同類對(duì)象
按值將對(duì)象傳遞給函數(shù)
函數(shù)按值返回對(duì)象
編譯器生成臨時(shí)對(duì)象

如果程序沒有使用復(fù)制構(gòu)造函數(shù),編譯器將提供原型,但不提供函數(shù)定義,否則,程序?qū)⒍x一個(gè)執(zhí)行成員初始化的賦值構(gòu)造函數(shù)。也就是說,新對(duì)象的每個(gè)成員都被初始化為原始對(duì)象相應(yīng)成員的值。如果成員為類對(duì)象,則初始化該成員時(shí),將使用相應(yīng)類的復(fù)制構(gòu)造函數(shù)。

如果使用new初始化的成員指針通常要求執(zhí)行深度復(fù)制,或者類可能包含需要修改的靜態(tài)變量。在上述情況下,需要定義自己的復(fù)制構(gòu)造函數(shù)。

3、  賦值構(gòu)造函數(shù)

默認(rèn)的賦值運(yùn)算符用于處理同類對(duì)象之間的賦值。不要將賦值與初始化混淆了。如果語(yǔ)句創(chuàng)建新的對(duì)象,則使用初始化,如果語(yǔ)句修改已有對(duì)象的值,則是賦值。

默認(rèn)賦值為成員賦值。如果成員為類對(duì)象,則默認(rèn)成員賦值將使用相應(yīng)類的賦值運(yùn)算符。如果需要顯示定義復(fù)制構(gòu)造函數(shù),則基于相同的原因。也需要顯示定義賦值運(yùn)算符。
 
對(duì)于派生類而言,保護(hù)成員類似于共有成員,但對(duì)于外部而言,保護(hù)成員于私有成員類似。派生類可以直接訪問基類的保護(hù)成員,但只能通過基類的成員函數(shù)來訪問私有成員。
 
基類的析構(gòu)函數(shù)應(yīng)當(dāng)是虛的。這樣,當(dāng)通過指向?qū)ο蟮幕愔羔樆蛞脕韯h除派生對(duì)象時(shí),程序?qū)⑹紫日{(diào)用派生類的析構(gòu)函數(shù),然后調(diào)用基類的析構(gòu)函數(shù),而不僅僅是調(diào)用基類的析構(gòu)函數(shù)

如何判斷一個(gè)指針指向的對(duì)象的真實(shí)類型,使用C++中的運(yùn)行時(shí)機(jī)制,typeid就可以實(shí)現(xiàn)目標(biāo)

以上就是小編為大家?guī)淼脑斦凜++何時(shí)需要定義賦值/復(fù)制構(gòu)造函數(shù)全部?jī)?nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

  • C++用Dijkstra(迪杰斯特拉)算法求最短路徑

    C++用Dijkstra(迪杰斯特拉)算法求最短路徑

    Dijkstra(迪杰斯特拉)算法是典型的最短路徑路由算法,用于計(jì)算一個(gè)節(jié)點(diǎn)到其他所有節(jié)點(diǎn)的最短路徑。主要特點(diǎn)是以起始點(diǎn)為中心向外層層擴(kuò)展,直到擴(kuò)展到終點(diǎn)為止。下面這篇文章就給大家介紹關(guān)于C++用Dijkstra算法(迪杰斯特拉算法)求最短路徑的方法,下面來一起看看吧。
    2016-12-12
  • C語(yǔ)言中#define與typedef的互換細(xì)節(jié)詳解

    C語(yǔ)言中#define與typedef的互換細(xì)節(jié)詳解

    本篇文章是對(duì)C語(yǔ)言中#define與typedef的互換細(xì)節(jié)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語(yǔ)言 格式化讀寫文件詳解

    C語(yǔ)言 格式化讀寫文件詳解

    本文主要介紹C語(yǔ)言 格式化讀寫文件,這里提供了關(guān)于格式化讀寫文件的基本資料及實(shí)現(xiàn)示例代碼,有興趣的小伙伴可以參考下,以便理解學(xué)習(xí)
    2016-08-08
  • c++中的volatile和variant關(guān)鍵字詳解

    c++中的volatile和variant關(guān)鍵字詳解

    大家好,本篇文章主要講的是c++中的volatile和variant關(guān)鍵字詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Qt掃盲篇之QRegularExpression正則匹配總結(jié)

    Qt掃盲篇之QRegularExpression正則匹配總結(jié)

    QRegularExpression是Qt5.0引進(jìn)的,修復(fù)了很多bug,提高了效率,使用時(shí)建議使用QRegularExpression,下面這篇文章主要給大家介紹了關(guān)于Qt掃盲篇之QRegularExpression正則匹配的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • C++實(shí)現(xiàn)LeetCode(兩個(gè)有序數(shù)組的中位數(shù))

    C++實(shí)現(xiàn)LeetCode(兩個(gè)有序數(shù)組的中位數(shù))

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(兩個(gè)有序數(shù)組的中位數(shù)),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • VsCode搭建C語(yǔ)言運(yùn)行環(huán)境詳細(xì)過程及終端亂碼問題解決方案

    VsCode搭建C語(yǔ)言運(yùn)行環(huán)境詳細(xì)過程及終端亂碼問題解決方案

    這篇文章主要介紹了VsCode搭建C語(yǔ)言運(yùn)行環(huán)境以及終端亂碼問題解決,在VsCode中搭建C/C++運(yùn)行環(huán)境需要先安裝幾個(gè)插件,具體插件文中給大家詳細(xì)介紹,需要的朋友可以參考下
    2022-12-12
  • php正則表達(dá)式的基本語(yǔ)法總結(jié)

    php正則表達(dá)式的基本語(yǔ)法總結(jié)

    以下是對(duì)php正則表達(dá)式的基本語(yǔ)法進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過來參考下
    2013-10-10
  • 利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能

    利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能

    在R3層的模塊隱藏,我們需要做的就是將其該鏈表斷鏈,將某一模塊從這個(gè)雙向鏈表中摘除,這樣再調(diào)用傳統(tǒng)的API時(shí)就會(huì)搜索不到。本文重點(diǎn)給大家介紹利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能,感興趣的朋友一起看看吧
    2019-10-10
  • C++11中std::async的使用詳解

    C++11中std::async的使用詳解

    這篇文章主要介紹了C++11中std::async的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02

最新評(píng)論