深入理解c++常成員函數(shù)和常對(duì)象
先明確幾個(gè)概念:
1. 常對(duì)象只能調(diào)用常成員函數(shù)。
2. 普通對(duì)象可以調(diào)用全部成員函數(shù)。
3. 當(dāng)對(duì)一個(gè)對(duì)象調(diào)用成員函數(shù)時(shí),編譯程序先將對(duì)象的地址賦給this指針,然后調(diào)用成員函數(shù),每次成員函數(shù)存取數(shù)據(jù)成員時(shí),由隱含使用this指針。
4. 當(dāng)一個(gè)成員函數(shù)被調(diào)用時(shí),自動(dòng)向它傳遞一個(gè)隱含的參數(shù),該參數(shù)是一個(gè)指向這個(gè)成員函數(shù)所在的對(duì)象的指針。
5. 在C++中,this指針被隱含地聲明為: X *const this,這意味著不能給this 指針賦值;
在X類(lèi)的const成員函數(shù)中,this指針的類(lèi)型為:const X* const, 這說(shuō)明this指針?biāo)赶虻倪@種對(duì)象是不可修改的(即不能對(duì)這種對(duì)象的數(shù)據(jù)成員進(jìn)行賦值操作);
6. 由于this并不是一個(gè)常規(guī)變量,所以,不能取得this的地址。
如:
#include <iostream>
class A
{
public:
A():mValue(0)
{
}
void print()
{
std::cout<<"hello";
}
int GetValue()
{
return mValue;
}
int GetValue()const
{
return mValue;
}
private:
int mValue;
};
void test(A & const a)
{
}
int main()
{
const A a;//const A* const this ;
a.print(); //錯(cuò)誤,將會(huì)提示 error C2662: “A::print”: 不能將“this”指針從“const A”轉(zhuǎn)換為“A &”
test(a); //error C2664: “test”: 不能將參數(shù) 1 從“const A”轉(zhuǎn)換為“A &”
}
由于a是const對(duì)象,所以a只能調(diào)用類(lèi)A中的常成員函數(shù)。
那么為什么會(huì)提示:“不能將this指針.......”的語(yǔ)句呢?
因?yàn)閷?duì)于c++的成員函數(shù)(當(dāng)然不是靜態(tài)成員函數(shù)),都會(huì)含有一個(gè)隱藏的參數(shù),對(duì)于上例A中的int GetValue()函數(shù),在編譯后會(huì)變成:
int GetValue(A * const this); //不能修改this變量,但可以修改this指向的內(nèi)容,即:this是常量指針。
而對(duì)于int GetValue()const ,編譯后是:
int GetValue(const A* const this);
只所以this指針是const類(lèi)型,因?yàn)樵谀炒握{(diào)用整個(gè)過(guò)程this指向都不允許改變(原因很簡(jiǎn)單,如果改變的話(huà)就不是這個(gè)對(duì)象調(diào)用的了)
從編譯后的結(jié)果看就很清楚了, 因?yàn)閍是const,所以其this指針就對(duì)應(yīng): const A* const this ;
而print函數(shù)被編譯出來(lái)后對(duì)應(yīng)的是void print(A* const this); 在進(jìn)行參數(shù)匹配時(shí), 所以就會(huì)提示 “不能將“this”指針從“const A ....."
this指針的出現(xiàn)就解釋了,所有類(lèi)A的對(duì)象都是公用一套代碼模版,為什么各個(gè)對(duì)象在調(diào)用成員函數(shù)的時(shí)候不會(huì)亂套。
原來(lái)C++為成員函數(shù)提供了一個(gè)名字為this的指針,這個(gè)指針?lè)Q為自引用指針。每當(dāng)創(chuàng)建一個(gè)對(duì)象時(shí),系統(tǒng)就把this指針初始化為指向該對(duì)象。每當(dāng)調(diào)用一個(gè)成員函數(shù)時(shí),系統(tǒng)就自動(dòng)把this指針作為一個(gè)隱含的參數(shù)傳給該函數(shù)。不同的對(duì)象調(diào)用同一個(gè)成員函數(shù)時(shí),C++編譯器將根據(jù)成員函數(shù)this指針?biāo)赶虻膶?duì)象來(lái)確定應(yīng)該引用哪一個(gè)對(duì)象的數(shù)據(jù)成員。通常情況下,this指針是隱含存在的,也可以將其顯示的表示出來(lái)(即如上例中的 this->mValue。不過(guò)this指針只能在類(lèi)中使用)
還有就是 this指針是一個(gè)const指針,不能再程序中修改它或給它賦值;
以上這篇深入理解c++常成員函數(shù)和常對(duì)象就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C語(yǔ)言交換奇偶位與offsetof宏的實(shí)現(xiàn)方法
offsetof()是C自帶的一個(gè)宏,它的作用就是計(jì)算結(jié)構(gòu)體成員相對(duì)于首地址處的偏移量,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言交換奇偶位與offsetof宏的實(shí)現(xiàn)方法,需要的朋友可以參考下2023-02-02
Qt5實(shí)現(xiàn)文本編輯器(附詳細(xì)代碼)
QT是一個(gè)跨平臺(tái)的GUI開(kāi)發(fā)框架,我使用的QT5 C++版本的,本文主要介紹了Qt5實(shí)現(xiàn)文本編輯器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
基于C中一個(gè)行壓縮圖的簡(jiǎn)單實(shí)現(xiàn)代碼
首先簡(jiǎn)單說(shuō)一下什么是行壓縮圖,其實(shí)嚴(yán)格意義上應(yīng)該是行壓縮矩陣2013-05-05
C++ STL priority_queue自定義排序?qū)崿F(xiàn)方法詳解
這篇文章主要介紹了C++ STL priority_queue自定義排序?qū)崿F(xiàn)方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)系列篇二叉樹(shù)的概念及滿(mǎn)二叉樹(shù)與完全二叉樹(shù)
在上一章中我們正式開(kāi)啟了對(duì)數(shù)據(jù)結(jié)構(gòu)中樹(shù)的講解,介紹了樹(shù)的基礎(chǔ)。本章我們將學(xué)習(xí)二叉樹(shù)的概念,介紹滿(mǎn)二叉樹(shù)和完全二叉樹(shù)的定義,并對(duì)二叉樹(shù)的基本性質(zhì)進(jìn)行一個(gè)簡(jiǎn)單的介紹。本章附帶課后練習(xí)2022-02-02
c++實(shí)現(xiàn)超簡(jiǎn)單的貪吃蛇游戲?qū)嵗榻B
大家好,本篇文章主要講的是c++實(shí)現(xiàn)超簡(jiǎn)單的貪吃蛇游戲?qū)嵗榻B,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話(huà)記得收藏一下,方便下次瀏覽2021-12-12

