std::monostate

来自cppreference.com
< cpp‎ | utility‎ | variant
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
 
在标头 <variant> 定义
struct monostate { };
(C++17 起)

有意作为 std::variant 中的行为良好的空可选项的单位类型。具体而言,非可默认构造的变体类型可以把 std::monostate 列为其首个可选项:这使得此变体自身可默认构造。

成员函数

(构造函数)
(隐式声明)
平凡隐式默认/复制/移动构造函数
(公开成员函数)
(析构函数)
(隐式声明)
平凡隐式析构函数
(公开成员函数)
operator=
(隐式声明)
平凡隐式复制/移动赋值
(公开成员函数)

非成员函数

std::operator==, !=, <, <=, >, >=, <=>(std::monostate)

constexpr bool operator==( monostate, monostate ) noexcept { return true; }
(1) (C++17 起)
(2)
constexpr bool operator!=( monostate, monostate ) noexcept { return false; }

constexpr bool operator< ( monostate, monostate ) noexcept { return false; }
constexpr bool operator> ( monostate, monostate ) noexcept { return false; }
constexpr bool operator<=( monostate, monostate ) noexcept { return true; }

constexpr bool operator>=( monostate, monostate ) noexcept { return true; }
(C++17 起)
(C++20 前)
constexpr std::strong_ordering operator<=>( monostate, monostate ) noexcept

{
    return std::strong_ordering::equal;

}
(C++20 起)

所有 std::monostate 实例比较相等。

<<=>>=!= 运算符分别从 operator<=>operator== 合成

(C++20 起)

辅助类

std::hash<std::monostate>

template <>
struct std::hash<monostate>;
(C++17 起)

std::monostate 特化 std::hash 算法。

示例

#include <cassert>
#include <iostream>
#include <variant>
 
struct S
{
    S(int i) : i(i) {}
    int i;
};
 
int main()
{
    // 若无 monostate 类型则此声明将失败。
    // 这是因为 S 不可默认构造。
    std::variant<std::monostate, S> var;
    assert(var.index() == 0);
 
    try
    {
        std::get<S>(var); // 将抛异常!我们需要先赋一个值
    }
    catch(const std::bad_variant_access& e)
    {
        std::cout << e.what() << '\n';
    }
 
    var = 42;
    std::cout << "std::get: " << std::get<S>(var).i << '\n'
              << "std::hash: " << std::hex << std::showbase
              << std::hash<std::monostate>{}(std::monostate{}) << '\n';
}

可能的输出:

std::get: wrong index for variant
std::get: 42
std::hash: 0xffffffffffffe19f

参阅

构造 variant 对象
(公开成员函数)