c++kquote>std::variant是C++17引入的类型安全联合体,可存储多种类型之一,需包含头文件;声明时指定允许的类型列表,如std::variant v;赋值时自动选择对应类型;访问值需使用std::get(v)或std::get_if(&v)确保类型安全,前者类型不匹配会抛出std::bad_variant_access异常,后者返回指针便于安全检查;可用std::holds_alternative(v)判断当前是否为某类型,或用v.index()获取类型索引;结合std::visit可对不同类型的值统一处理,支持泛型lambda或函数对象实现多态调用;适用于配置解析、表达式求值等场景,需编译器支持C++17及以上标准。

在C++17中引入的std::variant是一个类型安全的联合体(union),可以保存多种类型中的某一种值。它解决了传统union类型不安全的问题,使用起来更可靠且易于管理。
基本用法
std::variant定义在头文件中。声明一个variant时,需要指定它可以容纳的类型列表。
#include
#include iostream>
例如,创建一个可以存储int、double或std::string的variant:
std::variant v;
v = 42; // 存int
v = 3.14; // 存double
v = “hello”; // 存string
访问variant中的值
不能直接解引用variant,必须通过正确方式获取其当前持有的值。
立即学习“C++免费学习笔记(深入)”;
1. 使用std::get
可以通过类型或索引来获取值,但必须确保类型匹配,否则会抛出std::bad_variant_access异常。
v = 3.14;
if (std::holds_alternative(v)) {
double val = std::get(v);
std::cout }
2. 使用std::get_if
返回指针,适合检查并安全访问值。
if (auto* p = std::get_if(&v)) {
std::cout } else if (auto* p = std::get_if(&v)) {
std::cout }
判断当前类型
使用std::holds_alternative检查当前存储的类型:
if (std::holds_alternative(v)) {
std::cout }
也可以用v.index()获取当前类型的索引(从0开始):
switch (v.index()) {
case 0: /* int */ break;
case 1: /* double */ break;
case 2: /* string */ break;
}
结合std::visit进行类型分发
最强大的功能是配合std::visit,实现对不同类型的统一处理。
std::visit([](const auto& value) {
std::cout }, v);
也可以写成具名lambda或函数对象:
struct Printer {
void operator()(int i) const { std::cout void operator()(double d) const { std::cout void operator()(const std::string& s) const { std::cout };
std::visit(Printer{}, v);
基本上就这些。std::variant让多类型值的安全管理变得简单,特别适合解析配置、表达式求值、状态机等场景。注意编译器需支持C++17及以上标准,并开启对应模式(如g++ -std=c++17)。
以上就是c++++怎么使用std::variant_c++ std::variant使用方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1477046.html
微信扫一扫
支付宝扫一扫