std::variant是C++17引入的类型安全联合体,可持有多种类型之一并记录当前类型,避免传统union的类型安全隐患,支持复杂类型和std::visit等安全访问方式。

C++ 中的 std::variant 是 C++17 引入的一个类型安全的联合体(union)替代品,用于表示可以持有多种不同类型之一的对象。与传统的 union 不同,variant 是类型安全的,能够明确知道当前存储的是哪种类型,并且支持带有构造函数和析构函数的复杂类型。
传统的 C 风格 union 存在严重的类型安全隐患:
std::variant 解决了这些问题,它是一个“可辨识联合”(discriminated union),内部维护一个类型标签,确保每次访问都基于正确的类型。
包含头文件:#include
立即学习“C++免费学习笔记(深入)”;
定义一个 variant 变量:
std::variant<int, double, std::string> v;
这个 variant 可以保存 int、double 或 string 中的一种类型。默认初始化时,会使用第一个类型的默认构造函数(这里是 int(0))。
给 variant 赋值:
v = 42; // v holds int v = 3.14; // v now holds double v = "hello"; // v now holds std::string
直接解包 variant 需要小心,推荐以下几种方式:
1. std::get通过类型获取值,如果当前类型不匹配会抛出 std::bad_variant_access 异常:
try {
int i = std::get<int>(v);
} catch (const std::bad_variant_access& e) {
// 处理类型错误
}
通过索引访问(从0开始),同样可能抛异常:
double d = std::get<1>(v); // 获取第2个类型(double)
判断当前是否持有某类型:
if (std::holds_alternative<double>(v)) {
double d = std::get<double>(v);
}
使用访问者模式统一处理所有可能类型,支持 lambda 表达式:
std::visit([](auto&& arg) {
using T = std::decay_t<decltype(arg)>;
if constexpr (std::is_same_v<T, int>)
std::cout << "int: " << arg << "\n";
else if constexpr (std::is_same_v<T, double>)
std::cout << "double: " << arg << "\n";
else if constexpr (std::is_same_v<T, std::string>)
std::cout << "string: " << arg << "\n";
}, v);
这种方式是类型安全且可扩展的,适合处理复杂逻辑。
std::variant<std::monostate, std::function<void()>> callback; // 初始为空状态
基本上就这些。std::variant 提供了一种现代、安全、高效的方式来处理多类型变量,是传统 union 的理想替代方案。配合 std::visit 使用,代码更清晰、更少出错。合理使用能显著提升 C++ 程序的类型安全性和可维护性。
以上就是C++ variant用法解析_C++类型安全的union替代品详解的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号