命名空间
变体
操作

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 << "variant value: " << *pval << '\n';
        else
            std::cout << "failed to get value!" << '\n';
    };
 
    std::variant<int, float> v{12}, w{3.f};
    check_value(v);
    check_value(w);
}

输出

variant value: 12
failed to get value!

[编辑] 另请参阅

读取变体的值,给出索引或类型(如果类型是唯一的),在错误时抛出异常
(函数模板) [编辑]