std::variant是C++17引入的类型安全联合体,可存储多种类型之一,如int、double、string,默认构造使用首类型初始化;通过std::get按类型或索引访问值,类型不匹配时抛出异常;建议先用std::holds_alternative检查当前类型再取值;结合std::visit与lambda可实现类型自动分发处理,支持泛型和条件分支输出;注意不可存引用类型但可存reference_wrapper,生命周期自动管理,编译期确定类型,适用于配置解析、状态机等场景,使用时需重视类型检查与异常安全。

在C++17中引入的std::variant是一种类型安全的联合体(union),可以用来存储多种不同类型中的某一种值。它比传统的union更安全,也更易用,能有效避免未定义行为。
基本用法:定义和初始化
std::variant是一个模板类,接受多个类型作为参数,表示它可以保存这些类型之一。
示例:
#include
#include
std::variant v;</int>
立即学习“C++免费学习笔记(深入)”;
上面定义了一个可以保存int、double或std::string的变量v。默认构造时,它会使用第一个类型(这里是int)进行默认初始化。
也可以显式赋值:
v = 42; // 存储 int<br>v = 3.14; // 存储 double
v = "hello"; // 存储 string
访问 variant 中的值
不能直接解引用variant,需要通过特定方式获取其内容。
1. 使用 std::get
如果你知道当前存储的是哪种类型,可以用std::get(v)或std::get(v)获取值:
std::get<int>(v); // 按类型获取
std::get(v); // 按索引获取(int 是第0个)
如果类型不匹配,会抛出std::bad_variant_access异常。
2. 使用 std::holds_alternative 判断类型
在取值前,建议先判断当前存储的类型:
if (std::holds_alternative<int>(v)) {
std::cout << "int: " << std::get<int>(v);
}
使用 std::visit 处理多种类型
最强大的功能是std::visit,它可以对variant中的值应用一个可调用对象(如lambda),自动匹配类型。
示例:打印 variant 的值
std::visit([](const auto& value) {
std::cout << value << std::endl;
}, v);
这段代码会根据v当前持有的类型,自动选择正确的value类型并输出。
也可以写成多个 lambda 的结构化处理:
std::visit([&](const auto& arg) {
if constexpr (std::is_same_v) {
std::cout << "整数: " << arg;
} else if constexpr (std::is_same_v) {
std::cout << "浮点数: " << arg;
} else {
std::cout << "字符串: " << arg;
}
}, v);
常见注意事项
std::variant有一些使用时需要注意的地方:
不允许存储引用类型(如int&),但可以存std::reference_wrapper 一旦赋新值,旧值会被析构(自动管理生命周期) 性能上略高于普通 union,但远比继承+虚函数轻量 不支持动态添加类型,必须在编译期确定所有可能类型
适合场景:配置项解析、JSON-like 数据结构、状态机返回值、回调参数等需要“一个变量可能是几种类型之一”的情况。
基本上就这些。std::variant 提供了一种现代 C++ 中清晰且类型安全的方式来处理多类型存储问题,配合 visit 和 get 使用非常灵活。不复杂但容易忽略的是异常安全和类型检查的重要性。
以上就是c++++怎么使用std::variant来存储多种类型_c++ std::variant多类型存储用法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479738.html
微信扫一扫
支付宝扫一扫