typeid運算符,返回類型信息const std::type_info&。這種類型是不能賦值的。例如:
const std::typeinfo& a = typeid(int); //初始化可以
a = typeid(double); //再賦值就是錯誤
為了解決這個問題,C++引入了std::type_index類。這個類可以理解為封裝了一個指向typeinfo的指針。理論上,std::type_index是值語義的。例如:
std::type_index a = typeid(int); //實際是調用構造函數 std::type_index(typeid(int));
std::type_index b = a;
assert(a==b); //a,b都指向同一個type_info
b=typeid(double); //重新賦值
assert(a!=b); //a,b不再相同,a不受影響,仍指向int的type_info
std::cout <<a.name(); //實際調用的是底層type_info::name()函數
這樣就可以把type_index對象當做普通值(像int,std::string)一樣放到容器里,或者放到類中當做普通數據成員。
例子:不使用type_index
class SomeThing{};
int main(){
auto comp = [](const std::type_info* x, const std::type_info* y) -> bool {
return x->before(*y);
};
std::map< const std::type_info*, SomeThing, decltype(comp)> data(comp);
data[&typeid(int)] = SomeThing();
data[&typeid(double)] = SomeThing();
}
例子:使用type_index, 代碼清潔了很多
class SomeThing{};
int main(){
std::map< std::type_index, SomeThing> data;
data[typeid(int)] = SomeThing();
data[typeid(double)] = SomeThing();
}
————————————————
版權聲明:本文為CSDN博主「audi2」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/audi2/article/details/104014908