程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> C/C++中static,const,inline三種症結字具體總結

C/C++中static,const,inline三種症結字具體總結

編輯:關於C++

C/C++中static,const,inline三種症結字具體總結。本站提示廣大學習愛好者:(C/C++中static,const,inline三種症結字具體總結)文章只能為提供參考,不一定能成為您想要的結果。以下是C/C++中static,const,inline三種症結字具體總結正文


1、關於static
static 是C++中很經常使用的潤飾符,它被用來掌握變量的存儲方法和可見性,上面我將從 static 潤飾符的發生緣由、感化談起,周全剖析static 潤飾符的本質。

static 的兩年夜感化:

1、掌握存儲方法
static被引入以告訴編譯器,將變量存儲在法式的靜態存儲區而非棧上空間。

引出緣由:
函數外部界說的變量,在法式履行到它的界說處時,編譯器為它在棧上分派空間,年夜家曉得,函數在棧上分派的空間在此函數履行停止時會釋放失落,如許就發生了一個成績: 假如想將函數中此變量的值保留至下一次挪用時,若何完成?

最輕易想到的辦法是界說一個全局的變量,但界說為一個全局變量有很多缺陷,最顯著的缺陷是損壞了此變量的拜訪規模(使得在此函數中界說的變量,不只僅受此函數掌握)。

處理計劃:
是以C++ 中引入了static,用它來潤飾變量,它可以或許指導編譯器將此變量在法式的靜態存儲辨別配空間保留,如許即完成了目標,又使得此變量的存取規模不變。

2、掌握可見性與銜接類型 
static還有一個感化,它會把變量的可見規模限制在編譯單位中,使它成為一個外部銜接,這時候,它的反義詞為”extern”。

static感化剖析總結:
static老是使得變量或對象的存儲情勢釀成靜態存儲,銜接方法釀成外部銜接,關於部分變量(曾經是外部銜接了),它僅轉變其存儲方法;關於全局變量(曾經是靜態存儲了),它僅轉變其銜接類型。

類中的static成員
湧現緣由及感化:

1、須要在一個類的各個對象間交互,即須要一個數據對象為全部類而非某個對象辦事。

2、同時又力圖不損壞類的封裝性,即請求此成員隱蔽在類的外部,對外弗成見。

類的static成員知足了上述的請求,由於它具有以下特點:有自力的存儲區,屬於全部類。

留意:

1、關於靜態的數據成員,銜接器會包管它具有一個單一的內部界說。靜態數據成員按界說湧現的前後次序順次初始化,留意靜態成員嵌套時,要包管所嵌套的成員曾經初始化了。清除時的次序是初始化的反次序。

2、類的靜態成員函數是屬於全部類而非類的對象,所以它沒有this指針,這就招致了它僅能拜訪類的靜態數據和靜態成員函數。

2、關於const
const 是C++中經常使用的類型潤飾符,但我在任務中發明,很多人應用它僅僅是想固然爾,如許,有時也會用對,但在某些奧妙的場所,可就沒那末榮幸了,究其本質緣由,年夜多由於沒有弄清根源。這裡我將對const停止辨析。溯其根源,究其本質,願望能對年夜家懂得const有所贊助,依據思想的承接關系,分為以下幾個部門停止論述。

C++中為何會引入const

C++的提出者現在是基於甚麼樣的目標引入(或許說保存)const症結字呢?,這是一個風趣又無益的話題,對懂得const很有贊助。

1.年夜家曉得,C++有一個類型嚴厲的編譯體系,這使得C++法式的毛病在編譯階段便可發明很多,從而使得失足率年夜為削減,是以,同樣成為了C++與C比擬,有著凸起長處的一個方面。

2. C中很罕見的預處置指令 #define VariableName VariableValue 可以很便利地停止值替換,

這類值替換至多在三個方面長處凸起:

一是防止了意義隱約的數字湧現,使得法式語義流利清楚,以下例:
#define USER_NUM_MAX 107 如許就防止了直接應用107帶來的迷惑。

二是可以很便利地停止參數的調劑與修正,如上例,當人數由107變成201時,進修改此處便可;

三是進步了法式的履行效力,因為應用了預編譯器停止值替換,其實不須要為這些常量分派存儲空間,所以履行的效力較高。

鑒於以上的長處,這類預界說指令的應用在法式中到處可見。

3.說到這裡,年夜家能夠會困惑上述的1點、2點與const有甚麼關系呢?,好,請接著向下看來:

預處置語句固然有以上的很多長處,但它有個比擬致命的缺陷,即,預處置語句僅僅只是簡略值替換,缺少類型的檢測機制。如許預處置語句就不克不及享用C++嚴厲類型檢討的利益,從而能夠成為激發一系列毛病的隱患。

4.好了,第一階段結論出來了:

結論: const 推出的初始目標,恰是為了代替預編譯指令,清除它的缺陷,同時繼續它的長處。

如今它的情勢釀成了:

const DataType VariableName = VariableValue ;

為何const能很好地代替預界說語句?

const 究竟有甚麼年夜神通,使它可以振臂一揮代替預界說語句呢?

起首,以const 潤飾的常量值,具有弗成變性,這是它能代替預界說語句的基本。

第二,很顯著,它也異樣可以免意義隱約的數字湧現,異樣可以很便利地停止參數的調劑和修正。

第三,C++的編譯器平日不為通俗const常量分派存儲空間,而是將它們保留在符號表中,這使得它成為一個編譯時代的常量,沒有了存儲與讀內存的操作,使得它的效力也很高,同時,這也是它代替預界說語句的主要基本。

這裡,我要提一下,為何說這一點是也是它能代替預界說語句的基本,這是由於,編譯器不會去讀存儲的內容,假如編譯器為const分派了存儲空間,它就不克不及夠成為一個編譯時代的常量了。

最初,const界說也像一個通俗的變量界說一樣,它會由編譯器對它停止類型的檢測,清除了預界說語句的隱患。

const 應用情形分類詳析
1.const 用於指針的兩種情形剖析
 int const *A;  file://A可變,*A弗成變
 int *const A;  file://A弗成變,*A可變

剖析:const 是一個左聯合的類型潤飾符,它與其左邊的類型潤飾符和為一個類型潤飾符,所以,int const 限制 *A,不限制A。int *const 限制A,不限制*A。

2.const 限制函數的傳遞值參數
 void Fun(const int Var);
剖析:上述寫法限制參數在函數體中弗成被轉變。由值傳遞的特色可知,Var在函數體中的轉變不會影響到函數內部。所以,此限制與函數的應用者有關,僅與函數的編寫者有關。

結論:最好在函數的外部停止限制,對內部挪用者屏障,以避免惹起迷惑。如可改寫以下:

void Fun(int Var)
{
const int & VarAlias = Var;
VarAlias ....
.....
}

3. const 限制函數的值型前往值
const int Fun1();
const MyClass Fun2();

剖析:上述寫法限制函數的前往值弗成被更新,當函數前往外部的類型時(如Fun1),曾經是一個數值,固然弗成被賦值更新,所以,此時const有意義,最好去失落,以避免迷惑。當函數前往自界說的類型時(如Fun2),這個類型依然包括可以被賦值的變量成員,所以,此時成心義。

4. 傳遞與前往地址
此種情形最為罕見,由地址變量的特色可知,恰當應用const,意義昭然。

5. const 限制類的成員函數

class ClassName {

public:

int Fun() const;

   .....

}

留意:采取此種const 後置的情勢是一種劃定,亦為了不惹起混雜。在此函數的聲明中和界說中均要應用const,由於const曾經成為類型信息的一部門。

取得才能:可以操作常量對象。

掉去才能:不克不及修正類的數據成員,不克不及在函數中挪用其他不是const的函數。

3、關於inline
在下面談了const後,上面再來談一下inline這個症結字,之所以把inline放在這個地位,是由於inline這個症結字的引入緣由和const非常類似,上面分為以下幾個部門停止論述。

C++中引入inline症結字的緣由:
inline 症結字用來界說一個類的內聯函數,引入它的重要緣由是用它替換C中表達式情勢的宏界說。


表達式情勢的宏界說一例:
#define ExpressionName(Var1,Var2) (Var1+Var2)*(Var1-Var2)

為何要代替這類情勢呢,且聽我道來:

1.起首談一下在C中應用這類情勢宏界說的緣由,C說話是一個效力很高的說話,這類宏界說在情勢及應用上像一個函數,但它應用預處置器完成,沒有了參數壓棧,代碼生成等一系列的操作,是以,效力很高,這是它在C中被應用的一個重要緣由。

2.這類宏界說在情勢上相似於一個函數,但在應用它時,僅僅只是做預處置器符號表中的簡略調換,是以它不克不及停止參數有用性的檢測,也就不克不及享用C++編譯器嚴厲類型檢討的利益,別的它的前往值也不克不及被強迫轉換為可轉換的適合的類型,如許,它的應用就存在著一系列的隱患和局限性。

3.在C++中引入了類及類的拜訪掌握,如許,假如一個操作或許說一個表達式觸及到類的掩護成員或公有成員,你就弗成能應用這類宏界說來完成(由於沒法將this指針放在適合的地位)。

4. inline 推出的目標,也恰是為了代替這類表達式情勢的宏界說,它清除了它的缺陷,同時又很好地繼續了它的長處。

為何inline能很好地代替表達式情勢的預界說呢?

對應於下面的1-3點,論述以下:

1. inline 界說的類的內聯函數,函數的代碼被放入符號表中,在應用時直接停止調換,(像宏一樣睜開),沒有了挪用的開支,效力也很高。

2.很顯著,類的內聯函數也是一個真實的函數,編譯器在挪用一個內聯函數時,會起首檢討它的參數的類型,包管挪用准確。然落後行一系列的相干檢討,就像看待任何一個真實的函數一樣。如許就清除了它的隱患和局限性。

3. inline 可以作為某個類的成員函數,固然便可以在個中應用地點類的掩護成員及公有成員。

在什麼時候應用inline函數
起首,你可使用inline函數完整代替表達式情勢的宏界說。

別的要留意,內聯函數普通只會用在函數內容異常簡略的時刻,這是由於,內聯函數的代碼會在任何挪用它的處所睜開,假如函數太龐雜,代碼收縮帶來的惡果極可能會年夜於效力的進步帶來的好處。內聯函數最主要的應用處所是用於類的存取函數。

若何應用類的inline函數

簡略提一下inline 的應用吧:

1.在類中界說這類函數

class ClassName{
.....
....
GetWidth(){return m_lPicWidth;}; // 假如在類中直接界說,可以不應用inline潤飾
....
....
}

2.在類中聲明,在類外界說:

class ClassName{
.....
....
GetWidth(); // 假如在類中直接界說,可以不應用inline潤飾
....
....
}
inline ClassName::GetWidth()

{

return m_lPicWidth;

}

在本文中,談了一種特別的函數,類的inline函數,它的源起和特色在某種說法上與const很相似,可以與const搭配起來看。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved