std::any可存储任意类型,适用于类型未知但需安全访问的场景;std::variant是类型安全的联合体,适用于预定义类型的集合,二者均避免了void*的类型不安全问题。

在C++17中,std::any 和 std::variant 是两个新增的类型安全容器,它们解决了传统 void* 或联合体(union)带来的类型不安全问题。虽然两者都能存储不同类型的数据,但适用场景和设计目标不同。下面详细介绍它们的使用方法与区别。
std::any 可以保存任意单一类型的值,类似于“万能盒子”。它适用于你无法提前知道要存储什么类型,但又需要类型安全的场景。
基本用法:
#include <any>
std::any a = 42; // 存整数<br>a = std::string("hello"); // 改为字符串立即学习“C++免费学习笔记(深入)”;
访问值的方法:
std::any_cast 提取值,注意类型必须匹配,否则抛出 std::bad_any_cast 异常:try {<br> int value = std::any_cast<int>(a);<br>} catch (const std::bad_any_cast&) {<br> // 类型错误处理<br>}if (auto p = std::any_cast<double>(&a)) {<br> std::cout << *p;<br>} else {<br> std::cout << "not double";<br>}注意事项:
std::variant 是一个“类型安全的联合体”,只能保存其模板参数中列出的某一种类型。相比 any 更高效且可控。
基本用法:
#include <variant>
std::variant<int, std::string, double> v;<br>v = 42; // ok<br>v = "hello"s; // ok<br>// v = true; // 编译错误,bool 不在允许列表中
访问 variant 中的值:
std::get<T>(v) 或 std::get<index>(v),类型或索引错误会抛出 std::bad_variant_access
std::visit 进行类型安全的访问:std::visit([](const auto& val) {<br> std::cout << val;<br>}, v);visit 会根据当前存储的类型自动调用对应的 lambda 分支,是处理 variant 的最佳实践。
初始化与状态检查:
std::holds_alternative<T>(v) 检查当前是否存的是某种类型:if (std::holds_alternative<std::string>(v)) {<br> std::cout << "it's a string";<br>}关键在于使用场景:
variant 性能更好,类型更明确,编译期可检查;any 更灵活但运行时开销大。
基本上就这些。std::any 和 std::variant 让 C++ 在保持类型安全的前提下拥有了更强的泛型能力,合理使用可以替代不少不安全的 void* 或 union 用法。
以上就是C++怎么使用std::any和std::variant_C++17类型安全容器详解的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号