[問題] namespace alias還有一些觀念請教

看板C_and_CPP (C/C++)作者 (JOMI)時間7年前 (2018/05/31 13:22), 編輯推噓3(307)
留言10則, 3人參與, 7年前最新討論串1/1
遇到一個compile error https://stackoverflow.com/questions/17264067/chosen-constructor-is-explicit-in -copy-initialization-error-with-clang-4-2/17264506 加上了-D_GLIBCXX_DEBUG 不知道為什麼遇到類似以上這個error 用clang才會遇到 我寫 const vector<int> v = {}; 然而發現 加上這flag後 我寫std::vector 他其實是用到 std::__debug::vector 但仔細想想 .... 他怎麼做到的? 以下是我以為做得到的寫法 namespace AA { int a = 1; } namespace AA { namespace BB { int a = 2; } } namespace AA = AA::BB; int main() { std::cout<<AA::a<<std::endl; //希望能印2 return 0; } 看起來無法成功 有幾個問題 1. 他是怎麼做到std:: 讓他變成走std::__debug? 2. g++跟clang都走進去debug 版本的 vector constructor, 他有冠上explicit, 感覺上 g++也要出問題呀? 其實不太清楚clang跟gcc的關聯, 他們都走同一份實作那為什麼會有 不一樣的compile行為? 我可以解讀說 clang , gcc都是compiler, 但clang底下的stl source code是拿gcc的來 用? // 23.2.4.1 construct/copy/destroy: explicit vector(const _Allocator& __a = _Allocator()) : _Base(__a), _M_guaranteed_capacity(0) { } 3. 一般使用g++ -g 時 我自己的exe 包含了debug symbol, 但不意味著我link的glibc 是debug版? 所以如果我要真正的build一個debug版本的, 就必須要把-D_GLIBCXX_DEBUG 加上去? 還是根本無關.... 4. 到底這error 想表達的是什麼 (clang only) error: chosen constructor is explicit in copy-initialization const std::vector<int> v={}; 改成 const std::vector<int> v{}; 就沒事了 謝謝 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 110.28.64.60 ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1527744151.A.228.html

05/31 15:09, 7年前 , 1F
4是因為copy list init不能呼叫explicit
05/31 15:09, 1F

05/31 15:16, 7年前 , 2F
1應該是std加了using namespace std::__debug;
05/31 15:16, 2F

05/31 21:24, 7年前 , 3F
問題是我明確寫std::vector 還是走debug的耶 怎麼辦得
05/31 21:24, 3F

05/31 21:24, 7年前 , 4F
05/31 21:24, 4F

05/31 21:26, 7年前 , 5F
我看debug版本是繼承 一般版本的 但想不透他怎麼做到讓
05/31 21:26, 5F

05/31 21:26, 7年前 , 6F
我怎麼樣都使用debug version
05/31 21:26, 6F

05/31 21:27, 7年前 , 7F
可是4 用gcc沒事 是否是gcc有問題呢
05/31 21:27, 7F

05/31 22:20, 7年前 , 8F
1. 我猜inline namespace
05/31 22:20, 8F

05/31 22:28, 7年前 , 9F
05/31 22:28, 9F

05/31 22:43, 7年前 , 10F
可是inline namespace是c++11,那以前的要怎麼做?
05/31 22:43, 10F
文章代碼(AID): #1R3uQN8e (C_and_CPP)
文章代碼(AID): #1R3uQN8e (C_and_CPP)