C++構(gòu)建函數(shù)使用介紹
構(gòu)造函數(shù)概念:
構(gòu)造函數(shù)是一個(gè)特殊的成員函數(shù),名字與類(lèi)名相同,創(chuàng)建類(lèi)類(lèi)型對(duì)象時(shí)由編譯器自動(dòng)調(diào)用,保證每個(gè)數(shù)據(jù)成員都有一個(gè)合適的初始值,并且在對(duì)象的生命周期內(nèi)只調(diào)用一次(創(chuàng)建對(duì)象)
作用:
創(chuàng)建一個(gè)對(duì)象(面向?qū)ο?,第一步肯定得?chuàng)建對(duì)象)并且數(shù)據(jù)成員都有初始數(shù)值(數(shù)值有初始化和賦值)
初始化和賦值區(qū)別
- 初始化(數(shù)值在構(gòu)建函數(shù)中給予)
- 賦值(數(shù)值在構(gòu)建函數(shù)完成之后給予)
初始化(數(shù)值在構(gòu)建函數(shù)中給予)
#ifndef __COMPLEX__
#define __COMPLEX__
class complex
{
public:
complex(double r = 0, double i = 0)
: re(r), im(i) {} //初始化
private:
double re, im;
};
#endif // !__COMPLEX__#include"complex.h"
int main()
{
complex c1(1, 1);
return 0;
}
1.調(diào)用構(gòu)造函數(shù)
2.創(chuàng)建對(duì)象名字為c1
3.對(duì)象中數(shù)據(jù)成員與函數(shù)參數(shù)對(duì)應(yīng),進(jìn)行數(shù)值給予,生成對(duì)象的數(shù)據(jù)成員順序是類(lèi)中private的順序
4.對(duì)象c1創(chuàng)建成功
賦值(數(shù)值在構(gòu)建函數(shù)完成之后給予)
#ifndef __COMPLEX__
#define __COMPLEX__
class complex
{
public:
complex(double r = 0, double i = 0) //名字與類(lèi)名相同
{
re = r;
im = i;
}
private:
double re, im;
};
#endif // !__COMPLEX__#include"complex.h"
int main()
{
complex c1(1, 1);
return 0;
}
1.調(diào)用構(gòu)造函數(shù)
2.創(chuàng)建對(duì)象名字為c1
3.構(gòu)建函數(shù)中沒(méi)有初始化,編譯器自動(dòng)加上初始化操作,對(duì)數(shù)據(jù)成員進(jìn)行隨機(jī)數(shù)初始化
4.對(duì)象c1創(chuàng)建成功
5.函數(shù)中輸入的兩個(gè)參數(shù),函數(shù)執(zhí)行命令行,對(duì)數(shù)據(jù)進(jìn)行賦值
如何得知兩則區(qū)別
tihs指針
this指針中存儲(chǔ)的是自己對(duì)象的地址
在兩者構(gòu)造函數(shù)中使用this指針,初始化操作因?yàn)轭?lèi)對(duì)象完成初始化前,類(lèi)對(duì)象還未形成,所以會(huì)對(duì)this報(bào)錯(cuò)
初始化中使用this
class complex
{
public:
complex(double r = 0, double i = 0)
: this->re(r),this-> im(i) {}
private:
double re, im;
};error: expected '{' before 'this'
賦值中使用this
class complex
{
public:
complex(double r = 0, double i = 0)
{
this->im = r;
this->re = i;
}
private:
double re, im;
};
到此這篇關(guān)于C++構(gòu)建函數(shù)使用介紹的文章就介紹到這了,更多相關(guān)C++構(gòu)建函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C++類(lèi)與對(duì)象深入之構(gòu)造函數(shù)與析構(gòu)函數(shù)詳解
- C++超詳細(xì)講解拷貝構(gòu)造函數(shù)
- C++超詳細(xì)講解構(gòu)造函數(shù)與析構(gòu)函數(shù)的用法及實(shí)現(xiàn)
- C++探索構(gòu)造函數(shù)私有化會(huì)產(chǎn)生什么結(jié)果
- C++分析構(gòu)造函數(shù)與析造函數(shù)的特點(diǎn)梳理
- c++詳細(xì)講解構(gòu)造函數(shù)的拷貝流程
- C++構(gòu)造函數(shù)的類(lèi)型,淺拷貝與深拷貝詳解
- C++類(lèi)繼承時(shí)的構(gòu)造函數(shù)
- C++淺析構(gòu)造函數(shù)的特性
相關(guān)文章
C++實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(Map實(shí)現(xiàn))
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
C 語(yǔ)言基礎(chǔ)教程(我的C之旅開(kāi)始了)[二]
C 語(yǔ)言基礎(chǔ)教程(我的C之旅開(kāi)始了)[二]...2007-02-02
使用C++17實(shí)現(xiàn)JSON庫(kù)設(shè)計(jì)思路示例全解
這篇文章主要為大家介紹了使用C++17實(shí)現(xiàn)JSON庫(kù)設(shè)計(jì)思路示例全解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
C++實(shí)現(xiàn)LeetCode(159.最多有兩個(gè)不同字符的最長(zhǎng)子串)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(159.最多有兩個(gè)不同字符的最長(zhǎng)子串),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C語(yǔ)言深入淺出講解直接插入排序算法的實(shí)現(xiàn)
插入排序也是最簡(jiǎn)單的一類(lèi)排序方法,我今天介紹的也是插入排序里最直觀且淺顯易懂的直接插入排序。對(duì)這個(gè)很簡(jiǎn)單的排序,記得當(dāng)時(shí)也是花了近兩個(gè)晚上才搞懂它的原理的,接下來(lái)就來(lái)介紹一下2022-05-05
QT TCP實(shí)現(xiàn)簡(jiǎn)單的通信示例
這篇文章主要為大家詳細(xì)介紹了QT TCP簡(jiǎn)單的通信示例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08
C++全面細(xì)致講解復(fù)數(shù)類(lèi)
本文章向大家介紹C++ 標(biāo)準(zhǔn)庫(kù)中的復(fù)數(shù)類(lèi),主要包括C++ 標(biāo)準(zhǔn)庫(kù)中的復(fù)數(shù)類(lèi)使用實(shí)例、應(yīng)用技巧、基本知識(shí)點(diǎn)總結(jié)和需要注意事項(xiàng),具有一定的參考價(jià)值,需要的朋友可以參考一下2022-06-06
C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)貪吃蛇游戲設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07

