2022-01-11 14:52:07|已瀏覽:170次
可能很多程序員對C++已經非常熟悉,但是對命名空間經常使用到的地方還不是很明白,這篇文章就針對命名空間這一塊做了一個敘述。
命名空間在1995年被引入到 c++ 標準中,通常是這樣定義的:命名空間定義了新的作用域。它們提供了一種避免名稱沖突的方法。c++ 中的命名空間通常用于避免命名沖突。盡管命名空間在最近的 c++ 代碼中廣泛使用,但大多數較舊代碼都不使用此工具;趯Ρ姸郈++項目源碼的探索與研究,總結出了在這些項目中使用命名空間的一些常見原因。如果在同一個作用域內定義了具有相同名稱的枚舉,C++中的“傳統”枚舉會在其作用域內導出枚舉值,可能會導致名稱沖突,在一個大型項目中,不能保證兩個不同的枚舉都不會以同名命名。這個問題在C++ 11中已經得以解決,它使用枚舉類,隱式地對枚舉名稱中的枚舉值進行定義。
5、隱藏實現
對于在頭文件中實現的模板庫,開發者在調用時不需要用到特殊的數據類型,因為他們只專注于功能的實現,所以對于找到一種適合開發者調用庫的方法是很有趣的。在c#中, “internal” 關鍵字做了這項工作, 但是在c++中,沒有辦法將公有數據類型完全對開發者進行隱藏。在模塊中將定義和實現分離,是由Boost庫開發者們創建的一個c++慣用語法,但這些定義必須按照規則放入到一個可供開發者調用sub-namespace(子命名空間)中。
本文由培訓無憂網達內教育專屬課程顧問老師整理發布,更多C語言課程信息可關注培訓無憂網C語言培訓頻道或添加老師微信:15033336050
注:尊重原創文章,轉載請注明出處和鏈接 http://m.dedgn.cn/news-id-14648.html 違者必究!部分文章來源于網絡由培訓無憂網編輯部人員整理發布,內容真實性請自行核實或聯系我們,了解更多相關資訊請關注c語言頻道查看更多,了解相關專業課程信息您可在線咨詢也可免費申請試課。關注官方微信了解更多:150 3333 6050