網站首頁 編程語言 正文
一:背景
相信大家在分析 dump 時,經常會看到?WKS
?和?SRV
?這樣的字眼,如下代碼所示:
00007ffa`778a07b8 coreclr!WKS::gc_heap::segment_standby_list = 0x00000000`00000000 00007ffa`778a3870 coreclr!WKS::qpf = 0x989680 00007ffa`7789da30 coreclr!SVR::heap_select::numa_node_to_heap_map = unsigned short [1028] 00007ffa`7789f2d0 coreclr!SVR::gc_heap::should_expand_in_full_gc = 0n0
其實這就是命名空間,即 coreclr 在編譯源碼的時候,為?WKS
?和?SVR
?各編譯了一份,不知道這么做的初衷是什么,這里就不管了,接下來看下 coreclr 中大概長啥樣子。
namespace WKS { #include "gcimpl.h" #include "gc.cpp" } namespace SVR { #include "gcimpl.h" #include "gc.cpp" }
二:聊一聊 namespace
其實和 C# 的 namespace 本質差不多,都是起到隔離的作用,而且和 using 的配合使用和 C# 也是如出一轍,太有意思了。
1. 簡單的隔離
在 C++ 中默認只有一個 namespace,所以相同的變量會出現沖突,解決辦法就是用 namespace 隔離,參考如下代碼:
namespace WKS { int a = 10; int b = 11; } namespace SRV { int a = 100; int b = 101; } int main() { printf("WKS::a= %d \n", WKS::a); printf("SRV::a= %d \n", SRV::a); }
當然還可以嵌套使用,比如改成這樣。
namespace WKS { namespace V1 { int a = 10; int b = 11; } } int main() { printf("WKS::a= %d \n", WKS::V1::a); }
接下來看下匯編代碼:
哈哈,看到上面的?WKS::V1::a
?感覺是不是挺舒服的,也特能理解目前的?coreclr!WKS::xxx
?了, 不過這里有一個麻煩的地方,就是每次用?a
?的時候都要輸入很長的前綴,那有沒有簡化的方法呢? 當然有啦。
2. 使用 using 導入
接下來我們用 using 直接在 main 函數中定義字段,后續就不需要再寫長長的前綴引用了,參考代碼如下:
namespace WKS { namespace V1 { int a = 10; int b = 11; } } int main() { using WKS::V1::a; printf("WKS::V1::a1= %d \n", a); }
3. 使用 using 定義別名
定義別名這功能特別好,個人感覺已經完全替代以前的?typedef
?功能,比如下面的代碼是完全一樣的。
int main() { typedef const char* PCHAR; using PCHAR2 = const char*; PCHAR ptr1 = "hello world1"; PCHAR2 ptr2 = "hello world2"; }
如果還不信的話,可以看下它們各自生成的匯編代碼。
PCHAR ptr1 = "hello world1"; 00007FF79856183B lea rax,[string "hello world1" (07FF798569C10h)] 00007FF798561842 mov qword ptr [ptr1],rax PCHAR2 ptr2 = "hello world2"; 00007FF798561846 lea rax,[string "hello world2" (07FF798569CE8h)] 00007FF79856184D mov qword ptr [ptr2],rax
4. 使用 using namespace 導入
這個是最普遍的,我們對系統庫的調用,無一不是用 using namespace 方式的,比如下面的代碼。
using namespace std; int main() { string str = "hello world"; }
接下來我們把 V1 導入到 main 方法中,這樣就可以自由自在的使用?WKS::V1
?中的內容了,參考如下代碼:
namespace WKS { namespace V1 { int a = 10; int b = 11; } } int main() { using namespace WKS::V1; printf("a=%d, b=%d", a, b); }
好了,這就是對 namespace 的一點理解,本篇就說這么多吧,希望對你有幫助。
原文鏈接:https://www.cnblogs.com/huangxincheng/p/16646061.html
相關推薦
- 2022-01-27 插入數據庫某個字段之前判斷是否重復
- 2022-05-05 深入講解下Rust模塊使用方式_相關技巧
- 2022-11-19 詳解C語言內核中的自旋鎖結構_C 語言
- 2022-04-28 Python的線程使用隊列Queue來改造轉賬場景_python
- 2022-05-17 MacOS系統(macmini macbook pro)上安裝RabbitMQ
- 2022-04-21 Android監聽ScrollView滑動距離的簡單處理_Android
- 2022-04-25 django數據庫遷移migration實現_python
- 2024-01-12 maven依賴沖突以及解決方法
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支