作者lovejomi (JOMI)
看板C_and_CPP
標題[問題] unique_ptr + pimpl 建構子解構子
時間Wed Sep 26 12:09:53 2018
看了一些文章“大概“知道pimpl+uniqueptr為什麼要把解構子宣告跟定義要分開
因為沒分開 compiler會gen code然後用到 deleter 間接需要 看到complete type
於是就做了一些實驗,然後就發現有些無法理解的地方
https://wandbox.org/permlink/QRaV5jfUA5wKgE4c
1. 這邊故意讓建構子定義不分開,就編譯不過. 不知道為什麼會去碰到deleter 我建構
子也沒刻意去new Foo
https://wandbox.org/permlink/GZwtpA8GUuilcGXP
vs
https://wandbox.org/permlink/DLCA2r2aXsg3MJ3f
都是把main用到Bar b; 遮掉 差異在 Bar.h內
~Bar() = default; vs ~Bar() {}
原本以為這兩個是幾乎等價的寫法 但似乎還是有差距
2. 但我不理解為什麼一個build的過一個不行?
最後又好奇的做一個實驗
基於以下會build error
https://ideone.com/vVQAbv
我試著把 class Foo{}; 定義在 Bar::Bar(){} and ~Bar(){} 下面
https://wandbox.org/permlink/vkPvz0rcMblhC8O9
竟然也build過了!?
3. 為什麼這樣不會說undecalre error. 其實寫code常常會遇到類似這種問題, 明明覺得
應該會build failed(因為宣告順序問題)
但莫名其妙沒error, 一時之間找不到例子, 有些情況發生在template, 但似乎有個"t
wo phase name lookup", 但這邊又不是template?
4. 也許都不用管太多, 是不是最正規的寫法就是 class內有unique_ptr 好習慣就是 建
構解構定義在class外,
但總覺得寫出 Bar::~Bar() = default; 一定會被問說怎麼不放在class裡面 或是直
接刪除不寫.
謝謝
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 39.9.226.34
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1537935000.A.F87.html
→ eye5002003: 把解構子寫出來不就沒事了,還有去搞懂何謂前置宣告 09/26 13:36
→ lovejomi: ?有寫啊 09/26 15:02
→ adrianshum: 可以分享一下你提到 Pimpl + unique_ptr 的文章嗎? 09/26 23:45
→ adrianshum: 我有點搞不懂,根據 Rule of Zero不是連 dtor 都不該 09/26 23:46
→ adrianshum: 出現嗎? 09/26 23:47
→ adrianshum: oops 當我沒說,default 也是符合rule of zero 09/27 00:00
→ eye5002003: 因此錯在於你隱藏的不夠確實,解構子也要放在cpp那邊 09/27 13:26
→ lovejomi: 現在是建構子為什麼也必須在那,還有其他問題 09/27 17:11
→ lovejomi: @adrianshum 請問default 也滿足rule of zero 是哪裡的 09/27 17:31
→ lovejomi: 規定呢 謝謝 09/27 17:31
推 Sirctal: 你可以去看effective modern C++裡面有大略講 09/27 20:00