std::type_index(轉)


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM