为什么要用 std::any?
void* 是不安全的指标,只存储内存地址而不带有型别资讯。
你需要手动转换型别(reinterpret_cast),
这很有可能会导致型别错误,而且不容易追踪。
std::any 则是型别安全的,
可以存储任意型别的值,并在执行时检查型别,
避免了错误的转型操作,提升程式的安全性。
void*的情况
Code:
#include <iostream>
void printValue(void* ptr) {
std::cout << *reinterpret_cast<int*>(ptr) << std::endl; // 需要转型
}
int main() {
int value = 42;
printValue(&value); // 必须传指标
return 0;
}
std::any的情况
Code:
#include <any>
#include <iostream>
void printValue(const std::any& value) {
std::cout << std::any_cast<int>(value) << std::endl; // 型别安全
}
int main() {
std::any value = 42; // 可以存放任意型别的值
printValue(value); // 无需手动转型
return 0;
}
并且std::any可以型别检查:
if (value.type() == typeid(int)) {...}
也可以侦测错误转换:
try {
std::cout << std::any_cast<int>(value) << std::endl; // 尝试转换为int
} catch (const std::bad_any_cast& e) {
std::cerr << "Error: " << e.what() << std::endl; // 捕获转换错误
// Error: bad any_cast
}
表格:
特性 void* std::any
型别安全 否,可能导致未定义行为 是,提供型别检查与安全转换
使用简单性 要手动追踪型别,不方便 不需要追踪型别,自动管理
动态型别支持 基本支持,但容易出错 完整支持,型别检查更严格
效能 较快,但风险更高 较慢,但更安全
适用场景 C 接口、低层次操作 Modern C++ 更推荐
点评:
std::any不是任何情况都能取代void*,
但在能取代的场合更好用。