跳到主要内容

std::holds_alternative

定义于头文件 <variant>

声明

自 C++17 起
template< class T, class... Types >
constexpr bool holds_alternative( const std::variant<Types...>& v ) noexcept;

检查变体 `v` 是否持有备选项 `T`。如果 `T` 在 `Types...` 中没有且仅出现一次,则此调用格式错误。

参数

`v` - 要检查的变体

返回值

如果变体当前持有备选项 `T`,则为 `true`,否则为 `false`。

示例

#include <variant>
#include <string>
#include <iostream>
int main()
{
std::variant<int, std::string> v = "abc";
std::cout << std::boolalpha
<< "variant holds int? "
<< std::holds_alternative<int>(v) << '\n'
<< "variant holds string? "
<< std::holds_alternative<std::string>(v) << '\n';
}
结果
variant holds int? false
variant holds string? true

std::holds_alternative

定义于头文件 <variant>

声明

自 C++17 起
template< class T, class... Types >
constexpr bool holds_alternative( const std::variant<Types...>& v ) noexcept;

检查变体 `v` 是否持有备选项 `T`。如果 `T` 在 `Types...` 中没有且仅出现一次,则此调用格式错误。

参数

`v` - 要检查的变体

返回值

如果变体当前持有备选项 `T`,则为 `true`,否则为 `false`。

示例

#include <variant>
#include <string>
#include <iostream>
int main()
{
std::variant<int, std::string> v = "abc";
std::cout << std::boolalpha
<< "variant holds int? "
<< std::holds_alternative<int>(v) << '\n'
<< "variant holds string? "
<< std::holds_alternative<std::string>(v) << '\n';
}
结果
variant holds int? false
variant holds string? true