名稱空間
變體
操作

std::piecewise_construct, std::piecewise_construct_t

來自 cppreference.com
< cpp‎ | 工具
 
 
 
 
在標頭檔案 <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> 的公共成員函式)