std::get_if (std::variant)

来自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> 定义
(1) (C++17 起)
template< std::size_t I, class... Types >

constexpr std::add_pointer_t<std::variant_alternative_t<I, std::variant<Types...>>>

    get_if( std::variant<Types...>* pv ) noexcept;
template< std::size_t I, class... Types >

constexpr std::add_pointer_t<const std::variant_alternative_t<I, std::variant<Types...>>>

    get_if( const std::variant<Types...>* pv ) noexcept;
(2) (C++17 起)
template< class T, class... Types >

constexpr std::add_pointer_t<T>

    get_if( std::variant<Types...>* pv ) noexcept;
template< class T, class... Types >

constexpr std::add_pointer_t<const T>

    get_if( const std::variant<Types...>* pv ) noexcept;
1) 基于索引的不抛出访问器:若 pv 不是空指针且 pv->index() == I,则返回指向 pv 所指向的变体中存储的值的指针。否则,返回空指针值。若 I 不是此变体的有效索引,则此调用非良构。
2) 基于类型的不抛出访问器:等价于 (1),其中 ITTypes... 中的零基索引。若 T 不是 Types... 中的独有元素,则此调用非良构。

模板形参

I - 要查找的索引
Type - 要查找的独有类型

参数

pv - 指向变体的指针

返回值

指向被指向的变体中存储值的指针,错误时为空指针。

示例

#include <iostream>
#include <variant>
 
int main()
{
    auto check_value = [](const std::variant<int, float>& v)
    {
        if (const int* pval = std::get_if<int>(&v))
            std::cout << "变体值: " << *pval << '\n';
        else
            std::cout << "获取值失败!" << '\n';
    };
 
    std::variant<int, float> v{12}, w{3.f};
    check_value(v);
    check_value(w);
}

输出:

变体值: 12
获取值失败!

参阅

以给定索引或类型(如果类型唯一)读取 variant 的值,错误时抛出异常
(函数模板)