" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++名稱空間介紹

 更新時(shí)間:2021年12月31日 11:50:30   作者:梁唐  
這篇文章主要介紹了C++名稱空間,這是一個(gè)很重要的概念——名稱空間,有些書本里翻譯成了命名空間,對(duì)應(yīng)的英文是namespace。下面來(lái)看文章對(duì)此的詳細(xì)介紹吧,需要的小伙伴可以參考一下

1.名稱空間

在C++當(dāng)中,名稱可以是變量、函數(shù)、結(jié)構(gòu)體、枚舉、類以及結(jié)構(gòu)體和類的成員。這本身并沒(méi)有問(wèn)題,但隨著項(xiàng)目的增大,名稱之間相互沖突的可能性也會(huì)大大增加。

比如我們使用了多個(gè)廠商的代碼,它們都定義了List,TreeNode類,但定義的方式不同,也就沒(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中的fetch可以和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)文章

  • 利用mmap實(shí)現(xiàn)文件拷貝功能

    利用mmap實(shí)現(xiàn)文件拷貝功能

    這篇文章主要為大家詳細(xì)介紹了利用mmap實(shí)現(xiàn)文件拷貝功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Qt實(shí)現(xiàn)櫻花飛舞效果

    Qt實(shí)現(xiàn)櫻花飛舞效果

    這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)櫻花飛舞效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • 詳解C++中的增量運(yùn)算符++和減量運(yùn)算符--的用法

    詳解C++中的增量運(yùn)算符++和減量運(yùn)算符--的用法

    這篇文章主要介紹了C++中的增量運(yùn)算符++和減量運(yùn)算符--的用法,分為前綴情況和后綴情況來(lái)講,需要的朋友可以參考下
    2016-01-01
  • 在C/C++項(xiàng)目中合理使用宏詳解

    在C/C++項(xiàng)目中合理使用宏詳解

    這篇文章主要介紹了在C/C++項(xiàng)目中合理使用宏詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • C++?plog日志使用方法介紹

    C++?plog日志使用方法介紹

    最近突然心血來(lái)潮,想學(xué)一下日志方面的操作。在網(wǎng)上找了很多日志相關(guān)的技術(shù),最終還是決定使用plog,小巧,快速,跨平臺(tái)
    2022-10-10
  • Windows系統(tǒng)下使用C語(yǔ)言編寫單線程的文件備份程序

    Windows系統(tǒng)下使用C語(yǔ)言編寫單線程的文件備份程序

    這篇文章主要介紹了Windows系統(tǒng)下使用C語(yǔ)言編寫單線程的文件備份程序,文中給出了實(shí)現(xiàn)的幾個(gè)關(guān)鍵代碼片段,剩下的只要套上main和線程調(diào)用的相關(guān)函數(shù)即可,非常詳細(xì),需要的朋友可以參考下
    2016-02-02
  • C++數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹(shù)的實(shí)現(xiàn)

    C++數(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-05
  • C++ VTK實(shí)例之高斯隨機(jī)數(shù)的生成

    C++ 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
  • EasyC++全局變量

    EasyC++全局變量

    這篇文章主要介紹了EasyC++全局變量
    2021-12-12
  • C語(yǔ)言折半查找法的超詳細(xì)講解

    C語(yǔ)言折半查找法的超詳細(xì)講解

    折半查找法也叫做?分查找,顧名思義就是把數(shù)據(jù)分成兩半,再判斷所查找的key在哪?半中,再重復(fù)上述步驟知道找到?標(biāo)key,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言折半查找法的相關(guān)資料,需要的朋友可以參考下
    2022-06-06

最新評(píng)論