in_place_t
, in_place_type_t
, in_place_index_t
struct
Introduzido no C++17.
Os in_place_t
tipos de marca , in_place_type_t
e in_place_index_t
são usados para selecionar o construtor sobrecarregado que cria o objeto no local da maneira desejada. Para os tipos que usam esses tipos de tag, eles também podem ajudar a evitar operações temporárias de cópia ou movimentação.
Sintaxe
struct in_place_t
{
explicit in_place_t() = default;
};
inline constexpr in_place_t in_place{};
template <class T>
struct in_place_type_t
{
explicit in_place_type_t() = default;
};
template <class T>
constexpr in_place_type_t<T> in_place_type{};
template <size_t I>
struct in_place_index_t
{
explicit in_place_index_t() = default;
};
template <size_t I>
constexpr in_place_index_t<I> in_place_index{};
Parâmetros
I
O índice em que o objeto é criado no local.
T
O tipo de objeto a ser criado.
Comentários
in_place_t
indica a construção no local de um objeto. Usado para criar objetos no local dentro de umstd::optional
arquivo .in_place_type_t
indica a construção no local de um objeto de um tipo específico. É útil porquestd::any
std::any
pode conter qualquer tipo de tipo, então precisamos especificar o tipo que ele contém.in_place_index_t
indica a construção in-loco de um objeto em um índice específico. Use comstd::variant
para especificar o índice em que o objeto é criado.
Os seguintes tipos de classe usam esses structs em seus construtores: expected
, optional
, single_view
, any
ou variant
.
Exemplo
#include <iostream>
#include <optional>
#include <any>
#include <variant>
// compile with /std:c++17
struct MyStruct
{
double value;
MyStruct(double v0, double v1 = 0) : value(v0 + v1) {}
};
int main()
{
// Construct a MyStruct directly inside opt
std::optional<MyStruct> opt(std::in_place, 29.0, 13.0);
// Construct a MyStruct object inside an any object
std::any a(std::in_place_type<MyStruct>, 3.14);
// Construct a MyStruct object inside a vector at index 0
std::variant<MyStruct, int> v(std::in_place_index<0>, 2.718);
if (opt)
{
std::cout << opt->value << ", ";
}
std::cout << std::any_cast<MyStruct>(a).value << ", "
<< std::get<0>(v).value;
return 0;
}
42, 3.14, 2.718
Requisitos
Cabeçalho: <utility>
Namespace: std
Opção do compilador: /std:c++17
ou posterior.