std::piecewise_construct, std::piecewise_construct_t
來自 cppreference.com
在標頭檔案 <utility> 中定義 |
||
struct piecewise_construct_t { explicit piecewise_construct_t() = default; }; |
(1) | (C++11 起) |
constexpr std::piecewise_construct_t piecewise_construct{}; |
(2) | (C++11 起) (C++17 起為 inline) |
1)
std::piecewise_construct_t
是一個空類標籤型別,用於區分接受兩個 tuple 引數的不同函式。2) 常量
std::piecewise_construct
是 (1) 的一個例項。不使用 std::piecewise_construct_t
的過載假定每個 tuple 引數成為 pair 的元素。使用 std::piecewise_construct_t
的過載假定每個 tuple 引數用於分段構造指定型別的新物件,該物件將成為 pair 的元素。
目錄 |
[編輯] 標準庫
以下標準庫型別和函式使用它作為消歧義標籤
實現二元組,即一對值 (類模板) | |
準備與給定型別所需的使用分配器構造方式匹配的引數列表 (函式模板) | |
一個由重複生成相同值組成的view (類模板) (定製點物件) |
[編輯] 示例
執行此程式碼
#include <iostream> #include <tuple> #include <utility> struct Foo { Foo(std::tuple<int, float>) { std::cout << "Constructed a Foo from a tuple\n"; } Foo(int, float) { std::cout << "Constructed a Foo from an int and a float\n"; } }; int main() { std::tuple<int, float> t(1, 3.14); std::cout << "Creating p1...\n"; std::pair<Foo, Foo> p1(t, t); std::cout << "Creating p2...\n"; std::pair<Foo, Foo> p2(std::piecewise_construct, t, t); }
輸出
Creating p1... Constructed a Foo from a tuple Constructed a Foo from a tuple Creating p2... Constructed a Foo from an int and a float Constructed a Foo from an int and a float
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 2510 | C++11 | 預設建構函式不是 explicit 的,可能導致歧義 | 改為 explicit |
[編輯] 另請參閱
構造新 pair ( std::pair<T1,T2> 的公共成員函式)
|