帶有不完整類型編譯錯誤的std::unique_ptr
std::unique_ptr 類別旨在管理物件的生命週期,並且它可以與完整類型和不完整類型一起使用。但是,當嘗試宣告具有不完整類型的 std::unique_ptr 時,如下面的程式碼片段所示:
class window { window(const rectangle& rect); private: class window_impl; // defined elsewhere std::unique_ptr<window_impl> impl_; // won't compile };
可能會出現有關使用不完整類型的編譯錯誤。這個錯誤源自於這樣一個事實:當pimpl 與std::unique_ptr 一起使用時,必須聲明一個析構函數:
class foo { class impl; std::unique_ptr<impl> impl_; public: foo(); // You may need a def. constructor to be defined elsewhere ~foo(); // Implement (with {}, or with = default;) where impl is complete };
如果沒有顯式聲明析構函數,編譯器會產生一個默認析構函數,這需要一個完整的析構函數。 foo::impl 類別的聲明。在處理不完整類型時,這可能會導致編譯錯誤。
要解決此問題,請為該類別實作一個析構函數,可以使用空主體,也可以設定為預設值,如上面的程式碼片段所示。這將確保編譯器可以正確處理由 std::unique_ptr 管理的物件的銷毀。
此外,在命名空間範圍內不支援使用具有不完整類型的 std::unique_ptr。相反,可以透過將 std::unique_ptr 包裝在提供析構函數的自訂結構中來獲得解決方法,如下面的程式碼片段所示:
class impl; struct ptr_impl : std::unique_ptr<impl> { ~ptr_impl(); // Implement (empty body) elsewhere } impl_;
以上是為什麼使用帶有不完整類型的 std::unique_ptr 會導致編譯錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!