Namespaces
Variants
Actions

std::holds_alternative

From cppreference.com
< cpp‎ | utility‎ | variant
 
 
Utilities library
General utilities
Relational operators (deprecated in C++20)
(C++20)(C++20)(C++20)  
(C++20)
(C++20)
(C++14)
(C++11)
(C++11)
(C++23)
(C++11)
(C++17)
Common vocabulary types
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)


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

Checks if the variant v holds the alternative T. The call is ill-formed if T does not appear exactly once in Types...

[edit] Parameters

v - variant to examine

[edit] Return value

true if the variant currently holds the alternative T, false otherwise.

[edit] Example

Run this code
#include <cassert>
#include <string>
#include <variant>
 
int main()
{
 std::variant <int, std::string > v = "abc";
 assert (not std::holds_alternative<int>(v));
 assert (std::holds_alternative<std::string >(v));
}

[edit] See also

returns the zero-based index of the alternative held by the variant
(public member function) [edit]
reads the value of the variant given the index or the type (if the type is unique), throws on error
(function template) [edit]
Retrieved from "https://en.cppreference.com/mwiki/index.php?title=cpp/utility/variant/holds_alternative&oldid=172845"

AltStyle によって変換されたページ (->オリジナル) /