C++名稱空間介紹
1.名稱空間
在C++當(dāng)中,名稱可以是變量、函數(shù)、結(jié)構(gòu)體、枚舉、類以及結(jié)構(gòu)體和類的成員。這本身并沒(méi)有問(wèn)題,但隨著項(xiàng)目的增大,名稱之間相互沖突的可能性也會(huì)大大增加。
比如我們使用了多個(gè)廠商的代碼,它們都定義了List,Tree
和Node
類,但定義的方式不同,也就沒(méi)辦法互相兼容。這個(gè)時(shí)候當(dāng)我們希望使用一個(gè)庫(kù)的List類,而使用另外一個(gè)的Tree類,就會(huì)非常麻煩。這類沖突被稱為名稱空間(namespace
)問(wèn)題。
1.1傳統(tǒng)C++名稱空間
我們先來(lái)復(fù)習(xí)一下幾個(gè)術(shù)語(yǔ)。
聲明區(qū)域:
聲明區(qū)域指的是可以在其中進(jìn)行聲明的區(qū)域,比如我們可以在函數(shù)外側(cè)聲明全局變量,對(duì)于全局變量,它的聲明區(qū)域就是其聲明所在的文件。對(duì)于函數(shù)中聲明的變量, 它的聲明區(qū)域就是其聲明所在的代碼塊。
潛在作用域:
潛在作用域的范圍比聲明區(qū)域更加精確,它從聲明語(yǔ)句處開(kāi)始一直到聲明區(qū)域的結(jié)尾。這是因?yàn)樽兞勘仨毝x之后才能使用,所以潛在作用域的范圍比聲明區(qū)域要小。
這里有一個(gè)細(xì)節(jié),變量并不一定在整個(gè)潛在作用域都是可見(jiàn)的。因?yàn)榭赡苓€會(huì)被嵌套在聲明區(qū)域中的同名變量隱藏。比如說(shuō)我們同時(shí)定義了一個(gè)全局變量和一個(gè)函數(shù)中的同名變量,那么在函數(shù)當(dāng)中,外側(cè)的全局變量將會(huì)被同名的局部變量隱藏。
作用域:
結(jié)合前面所說(shuō)的,變量對(duì)于程序而言可見(jiàn)的范圍被稱為作用域,它又比潛在作用域更加精確一些。
1.2新的名稱空間特性
C++新增了通過(guò)定義一種新的聲明區(qū)域來(lái)創(chuàng)建命名的名稱空間,這樣做的目的是提供一個(gè)聲明名稱的區(qū)域。一個(gè)名稱空間中的名稱不會(huì)與另外一個(gè)名稱空間的相同名稱發(fā)生沖突,同時(shí)允許程序的其他部分使用該名稱空間中聲明的東西。
比如C++ Primer
當(dāng)中的這個(gè)例子,下面使用新的關(guān)鍵字namespace
創(chuàng)建了兩個(gè)名稱空間A和B。
namespace A { double pail; void fetch(); int pal; struct Well {...}; } namespace B { double bucket(double n) {...} double fetch; int pal; struct Hill {...}; }
名稱空間可以是全局的,也可以位于另外一個(gè)名稱空間中,但不能位于代碼塊中。因此,默認(rèn)名稱空間里的所有聲明的名稱的鏈接性都是外部的,const
關(guān)鍵字修飾的常量除外。
除了用戶定義的名稱空間之外,還存在另外一個(gè)名稱空間——全局名稱空間。它對(duì)應(yīng)于文件級(jí)的聲明區(qū)域,因此前面所說(shuō)的全局變量現(xiàn)在被描述為位于全局名稱空間中。
任何名稱空間中的名稱都不會(huì)與其他空間的名稱發(fā)生沖突,因此A中的fet
ch可以和B中的fetch
共存。名稱空間中的聲明和定義規(guī)則桶全局聲明和定義的規(guī)則相同。
名稱空間是開(kāi)放的,可以把名稱加入到已經(jīng)創(chuàng)建的名稱空間中,比如:
namespace A { char *goose(const char *); }
同樣我們之前在名稱空間A當(dāng)中只是定義了函數(shù)fetch,而沒(méi)有定義,我們也可以在之后的代碼當(dāng)中添加定義:
namespace A { void fetch () { ... } }
當(dāng)然而我們需要一種方法來(lái)訪問(wèn)給定名稱空間里的名稱,最簡(jiǎn)單的方法是使用作用域解析符::,使用名稱空間名來(lái)找到該名稱:
A::pail = 12.34; A::fetch();
沒(méi)有作用域解析符的名稱成為未限定名稱,包含了名稱空間的名稱稱為限定的名稱。
這一篇當(dāng)中涉及了許多概念,看起來(lái)有些晦澀。但我個(gè)人感覺(jué),這些概念理解起來(lái)并不復(fù)雜,主要是一些說(shuō)明性的語(yǔ)言讀起來(lái)有些難以理解。最好的辦法就是沉下氣來(lái),一點(diǎn)點(diǎn)精讀,先把前面理解了再看后面。
到此這篇關(guān)于C++名稱空間介紹的文章就介紹到這了,更多相關(guān)C++名稱空間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C++中的增量運(yùn)算符++和減量運(yùn)算符--的用法
這篇文章主要介紹了C++中的增量運(yùn)算符++和減量運(yùn)算符--的用法,分為前綴情況和后綴情況來(lái)講,需要的朋友可以參考下2016-01-01Windows系統(tǒng)下使用C語(yǔ)言編寫單線程的文件備份程序
這篇文章主要介紹了Windows系統(tǒng)下使用C語(yǔ)言編寫單線程的文件備份程序,文中給出了實(shí)現(xiàn)的幾個(gè)關(guān)鍵代碼片段,剩下的只要套上main和線程調(diào)用的相關(guān)函數(shù)即可,非常詳細(xì),需要的朋友可以參考下2016-02-02C++數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹(shù)的實(shí)現(xiàn)
了解搜索二叉樹(shù)是為了STL中的map和set做鋪墊,我們所熟知的AVL樹(shù)和平衡搜索二叉樹(shù)也需要搜索二叉樹(shù)的基礎(chǔ)。本文將詳解如何利用C++實(shí)現(xiàn)搜索二叉樹(shù),需要的可以參考一下2022-05-05C++ VTK實(shí)例之高斯隨機(jī)數(shù)的生成
這篇文章主要介紹了VTK的一個(gè)實(shí)例之高斯隨機(jī)數(shù)的生成,本文演示了從一個(gè)平均數(shù)是0.0和標(biāo)準(zhǔn)偏差是2.2的高斯分布中隨機(jī)生成3個(gè)隨機(jī)數(shù)。感興趣的同學(xué)可以學(xué)習(xí)一下2021-11-11