名稱空間
變體
操作

std::out_ptr

來自 cppreference.com
< cpp‎ | 記憶體‎ | out ptr t
 
 
記憶體管理庫
(僅作說明*)
未初始化記憶體演算法
(C++17)
(C++17)
(C++17)
受約束的未初始化
記憶體演算法
C 庫

分配器
記憶體資源
垃圾回收支援
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
未初始化儲存
(直到 C++20*)
(直到 C++20*)
顯式生命週期管理
 
 
定義於標頭檔案 <memory>
template< class Pointer = void, class Smart, class... Args >
auto out_ptr( Smart& s, Args&&... args );
(C++23 起)

返回一個帶有推導模板引數的 std::out_ptr_t,它透過引用捕獲重置引數。

如果返回值的構造(見下文)格式錯誤,則程式格式錯誤。

目錄

[編輯] 引數

s - 要適配的物件(通常是智慧指標)
args... - 要捕獲的重置引數

[編輯] 返回值

std::out_ptr_t<Smart, P, Args&&>(s, std::forward<Args>(args)...),其中 P

  • Pointer,如果 Pointervoid 不同。否則,
  • Smart::pointer,如果它有效並表示一個型別。否則,
  • Smart::element_type*,如果 Smart::element_type 有效並表示一個型別。否則,
  • std::pointer_traits<Smart>::element_type*.

[編輯] 注意

使用者可以為模板引數 Pointer 指定模板引數,以便與接受 Pointer* 的外部函式進行互操作。

由於所有重置引數都是透過引用捕獲的,因此返回的 out_ptr_t 應該是一個臨時物件,並在包含對外部函式呼叫的完整表示式結束時銷燬,以避免懸空引用。

特性測試 標準 特性
__cpp_lib_out_ptr 202106L (C++23) std::out_ptr, std::inout_ptr
202311L (C++26) 獨立的 std::out_ptrstd::inout_ptr

[編輯] 示例

使用 std::out_ptr 適配智慧指標以用於 sqlite3_open,它需要一個 sqlite3** 作為輸出引數。

#include <memory>
#include <sqlite3.h>
 
int main()
{
    auto close_db = [](sqlite3* db) { sqlite3_close(db); };
 
    {
        // open an in-memory database, and manage its lifetime with std::unique_ptr
        std::unique_ptr<sqlite3, decltype(close_db)> up;
        sqlite3_open(":memory:", std::out_ptr(up));
 
        sqlite3* db = up.get();
        // do something with db ...
    }
    {
        // same as above, but use a std::shared_ptr
        std::shared_ptr<sqlite3> sp;
        sqlite3_open(":memory:", std::out_ptr(sp, close_db));
 
        sqlite3* db = sp.get();
        // do something with db ...
    }
}

[編輯] 另請參閱

(C++23)
建立一個帶有關聯智慧指標和重置引數的 inout_ptr_t
(函式模板) [編輯]
建立一個管理新物件的唯一指標
(函式模板) [編輯]
建立一個管理新物件的共享指標
(函式模板) [編輯]