C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- å鿍¡æ¿(C++14 èµ·)
- æ´æ°åé¢é
- èååå§å
- æ¯è¾è¿ç®ç¬¦
- é»è®¤æ¯è¾(C++20 èµ·)
- 转ä¹åºå
- for 循ç¯
- while 循ç¯
- ç¨æ·å®ä¹è½¬æ¢
- SFINAE
- 䏻彿°
- ASCII ç 表
- æ è¯ç¬¦
- ç±»å
- å 忍¡å
- 对象
- åºæ¬æ¦å¿µ
- 表达å¼
- 声æ
- åå§å
- 彿°
- è¯å¥
- ç±»
- è¿ç®ç¬¦éè½½
- 模æ¿
- å¼å¸¸
- äºå¡æ§å å
- å ä½ç¬¦ç±»å说æç¬¦ (C++11 èµ·)
- decltype 说æç¬¦
- 彿°å£°æ
- final 说æç¬¦ (C++11 èµ·)
- override 说æç¬¦(C++11 èµ·)
- å¼ç¨å£°æ
- ç§»å¨æé 彿°
- ç§»å¨èµå¼è¿ç®ç¬¦
- æä¸¾å£°æ
- constexpr 说æç¬¦(C++11 èµ·)
- å表åå§å (C++11 èµ·)
- æé 彿°ä¸æååå§åå¨å表
- using 声æ
- nullptrï¼æéåé¢é
- åºç¡ç±»å
- ç±»åå«åï¼å«å模ç (C++11 èµ·)
- å½¢åå
- èåä½å£°æ
- å符串åé¢é
- ç¨æ·å®ä¹åé¢é (C++11 èµ·)
- 屿§è¯´æç¬¦åºå(C++11 èµ·)
- Lambda è¡¨è¾¾å¼ (C++11 èµ·)
- noexcept 说æç¬¦ (C++11 èµ·)
- noexcept è¿ç®ç¬¦ (C++11 èµ·)
- alignof è¿ç®ç¬¦(C++11 èµ·)
- alignas 说æç¬¦ (C++11 èµ·)
- åå¨ç±»è¯´æç¬¦
- åºäºèå´ç for å¾ªç¯ (C++11 èµ·)
- static_assert 声æ
- éå¼è½¬æ¢
- 代ç¨è¿ç®ç¬¦è¡¨ç¤º
- èªå¢/èªåè¿ç®ç¬¦
- æå 表达å¼(C++17 èµ·)
- 类模æ¿å®åæ¨å¯¼(C++17 èµ·)
- 模æ¿å½¢å䏿¨¡æ¿å®å
- if è¯å¥
- inline 说æç¬¦
- ç»æåç»å®å£°æ (C++17 èµ·)
- switch è¯å¥
- å符åé¢é
- å½å空é´
- æ±å¼é¡ºåº
- å¤å¶æ¶é¤
- consteval 说æç¬¦ (C++20 èµ·)
- constinit 说æç¬¦ (C++20 èµ·)
- åç¨ (C++20)
- 模å (C++20 èµ·)
- 约æä¸æ¦å¿µ (C++20 èµ·)
- new 表达å¼
- do-while 循ç¯
- continue è¯å¥
- break è¯å¥
- goto è¯å¥
- return è¯å¥
- 卿å¼å¸¸è¯´æ
- throw 表达å¼
- try å
- å½å空é´å«å
- 类声æ
- cvï¼const ä¸ volatileï¼ç±»åéå®ç¬¦
- é»è®¤åå§å
- å¼åå§å(C++03 èµ·)
- é¶åå§å
- å¤å¶åå§å
- ç´æ¥åå§å
- 常éåå§å
- å¼ç¨åå§å
- å¼ç±»å«
- C++ è¿ç®ç¬¦ä¼å 级
- å¸å°åé¢é
- æµ®ç¹åé¢é
- typedef 说æç¬¦
- æ¾å¼ç±»å转æ¢
- static_cast 转æ¢
- dynamic_cast 转æ¢
- const_cast 转æ¢
- reinterpret_cast 转æ¢
- delete 表达å¼
- æé 彿°ä¸æååå§åå¨å表
- this æé
- 访é®è¯´æç¬¦
- åå 声æ
- virtual 彿°è¯´æç¬¦
- explicit 说æç¬¦
- éææå
- é»è®¤æé 彿°
- å¤å¶æé 彿°
- å¤å¶èµå¼è¿ç®ç¬¦
- ææå½æ°
- 类模æ¿
- 彿°æ¨¡æ¿
- æ¾å¼ï¼å ¨ï¼æ¨¡æ¿ç¹å
- æ±ç¼å£°æ
- C++ çåå²
- ä½ç¨å
- çåæ
- å®ä¹ä¸åä¸å®ä¹è§åï¼ODRï¼
- å忥æ¾
- æéå®çå忥æ¾
- æ éå®çå忥æ¾
- å¦åè§å
- æªå®ä¹è¡ä¸º
- ç¿»è¯é¶æ®µ
- 常é表达å¼
- èµå¼è¿ç®ç¬¦
- ç®æ¯è¿ç®ç¬¦
- é»è¾è¿ç®ç¬¦
- æå访é®è¿ç®ç¬¦
- å ¶ä»è¿ç®ç¬¦
- sizeof è¿ç®ç¬¦
- typeid è¿ç®ç¬¦
- æé声æ
- æ°ç»å£°æ
- è¯è¨é¾æ¥
- 详述类å说æç¬¦
- é»è®¤å®å
- åé¿å®å
- å®åä¾èµæ¥æ¾
- éè½½å³è®®
- éè½½å½æ°çå°å
- æ³¨å ¥ç±»å
- ééææ°æ®æå
- ééææå彿°
- åµå¥ç±»
- æ´¾çç±»
- 空åºç±»ä¼å
- æ½è±¡ç±»
- ä½å
- è½¬æ¢æé 彿°
- æå模æ¿
- 模æ¿å®åæ¨å¯¼
- é¨å模æ¿ç¹å
- sizeof... è¿ç®ç¬¦
- å¾ å³å
- 彿° try å
- æ©å å½åç©ºé´ std
- åæ¯ç¼©å
- RAII
- ä¸/äº/é¶ä¹æ³å
- PImpl
- é¶å¼éåå
- ç±»å
- éå¼è½¬æ¢
- 注é
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >C++ è¯è¨ > dynamic_cast 转æ¢
dynamic_cast 转æ¢
沿继æ¿å±çº§åä¸ãåä¸åä¾§åï¼å®å ¨å°è½¬æ¢å°å ¶ä»ç±»çæéåå¼ç¨ã
è¯æ³
dynamic_cast < æ°ç±»å > ( è¡¨è¾¾å¼ )
|
|||||||||
| æ°ç±»å | - | æå宿´ç±»ç±»åçæéãå°å®æ´ç±»ç±»åçå¼ç¨ï¼ææåï¼å¯éç cv éå®ï¼void çæé |
| è¡¨è¾¾å¼ | - | è¥ æ°ç±»å 为å¼ç¨ï¼åä¸ºå®æ´ç±»ç±»åçå·¦å¼ (C++11 å)æ³å·¦å¼ (C++11 èµ·)表达å¼ï¼è¥ æ°ç±»å 为æéï¼å为æå宿´ç±»ç±»åçæé纯å³å¼ã |
è¥è½¬åæåï¼å dynamic_cast è¿å æ°ç±»å ç±»åçå¼ãè¥è½¬åå¤±è´¥ä¸ æ°ç±»å æ¯æéç±»åï¼åå®è¿å该类åç空æéãè¥è½¬åå¤±è´¥ä¸ æ°ç±»å æ¯å¼ç¨ç±»åï¼å宿åºä¸ç±»å std::bad_cast çå¤çåå¹é
çå¼å¸¸ã
è§£é
坿ä¸å转æ¢è½ç¨ dynamic_cast è¿è¡ï¼ä½è¥è¿ç§è½¬æ¢ä¼è½¬æ¢èµ°å¸¸éæ§ææåæ§å亦ä¸å 许ã
1) è¥ è¡¨è¾¾å¼ çç±»åæ°æ¯ æ°ç±»å æ æ°ç±»å çè¾å° cv éå®çæ¬ï¼åç»ææ¯ è¡¨è¾¾å¼ å
·æ æ°ç±»å ç±»åçå¼ãï¼æ¢è¨ä¹ï¼dynamic_cast å¯ç¨ä»¥æ·»å 叏鿧ãéå¼è½¬æ¢å static_cast 亦è½è¿è¡æ¤è½¬æ¢ãï¼
2) è¥ è¡¨è¾¾å¼ ç弿¯ç©ºæéå¼ï¼åç»ææ¯ æ°ç±»å ç±»åç空æéå¼ã
3) è¥ æ°ç±»å æ¯å°
Base çæéæå¼ç¨ï¼ä¸ è¡¨è¾¾å¼ çç±»åæ¯å° Derived çæéæå¼ç¨ï¼å
¶ä¸ Base æ¯ Derived çå¯ä¸å¯è®¿é®åºç±»ï¼åç»ææ¯å° è¡¨è¾¾å¼ ææ è¯çå¯¹è±¡ä¸ Base ç±»å对象çæéæå¼ç¨ãï¼æ³¨æï¼éå¼è½¬æ¢å static_cast 亦è½è¿è¡æ¤è½¬æ¢ãï¼4) è¥ è¡¨è¾¾å¼ æ¯æåå¤æç±»åçæéï¼ä¸ æ°ç±»å æ¯å° void çæéï¼åç»ææ¯æå è¡¨è¾¾å¼ ææåæå¼ç¨çæç»æ´¾ç对象çæéã
5) è¥ è¡¨è¾¾å¼ æ¯å°å¤æç±»å
Base çæéæå¼ç¨ï¼ä¸ æ°ç±»å æ¯å° Derived ç±»åçæéæå¼ç¨ï¼åè¿è¡è¿è¡æ¶æ£æ¥ï¼a) æ£éª è¡¨è¾¾å¼ ææå/æ è¯çæç»æ´¾ç对象ãè¥å¨è¯¥å¯¹è±¡ä¸ è¡¨è¾¾å¼ æå/æä»£
Derived çå
¬å¼åºç±»ï¼ä¸åªæä¸ä¸ª Derived ç±»åå¯¹è±¡ä» è¡¨è¾¾å¼ ææå/æ è¯çå对象派çï¼å转åç»ææå/æä»£è¯¥ Derived 对象ãï¼æ¤ä¹è°âåä¸è½¬åï¼downcastï¼âãï¼b) å¦åï¼è¥ è¡¨è¾¾å¼ æå/æä»£æç»æ´¾ç对象çå
¬å¼åºç±»ï¼èåæ¶æç»æ´¾çå¯¹è±¡æ¥æ
Derived ç±»åçæ æ§ä¹å
¬å¼åºç±»ï¼å转åç»ææå/æä»£è¯¥ Derivedï¼æ¤ä¹è°âä¾§å转åï¼sidecastï¼âãï¼c) å¦åï¼è¿è¡æ¶æ£æ¥å¤±è´¥ãè¥ dynamic_cast ç¨äºæéï¼åè¿å æ°ç±»å ç±»åç空æéå¼ãè¥å®ç¨äºå¼ç¨ï¼åæåº std::bad_cast å¼å¸¸ã
6) å½å¨æé 彿°æææå½æ°ä¸ï¼ç´æ¥æé´æ¥ï¼ä½¿ç¨ dynamic_castï¼ä¸ è¡¨è¾¾å¼ æä»£æ£å¨æé /鿝ç对象æ¶ï¼è¯¥å¯¹è±¡è¢«è®¤ä¸ºæ¯æç»æ´¾ç对象ãè¥ æ°ç±»å 䏿¯å°æé 彿°/ææå½æ°èªèº«çç±»æå
¶åºç±»ä¹ä¸çæéæå¼ç¨ï¼åè¡ä¸ºæªå®ä¹ã
ä¸å ¶ä»è½¬å表达å¼ç¸ä¼¼ï¼
- è¥ æ°ç±»å æ¯å·¦å¼å¼ç¨ç±»åï¼è¡¨è¾¾å¼ å¿ ä¸ºå·¦å¼ï¼ï¼åå ¶ç»æä¸ºå·¦å¼
- è¥ æ°ç±»å æ¯å³å¼å¼ç¨ç±»åï¼è¡¨è¾¾å¼ ä¸ºå®æ´ç±»ç±»åï¼å¯ä»¥æ¯å·¦å¼æå³å¼ (C++17 å)å¿ ä¸ºæ³å·¦å¼ï¼çº¯å³å¼è¢«å®è´¨åï¼ (C++17 èµ·)ï¼ï¼åå ¶ç»æä¸ºäº¡å¼
- è¥ æ°ç±»å æ¯æéç±»åï¼åå ¶ç»æä¸ºçº¯å³å¼
注解
- 亦å¯ç¨ static_cast è¿è¡åä¸è½¬åï¼å®é¿å
è¿è¡æ¶æ£æ¥çå¼éï¼ä½åªæå¨ç¨åºï¼éè¿æäºå
¶ä»é»è¾ï¼è½å¤ä¿è¯ è¡¨è¾¾å¼ ææåç对象è¯å®æ¯
Derivedæ¶ææ¯å®å ¨çã - æäºå½¢å¼ç dynamic_cast ä¾èµäºè¿è¡æ¶ç±»åé´å«ï¼ RTTI ï¼ï¼å³ç¼è¯çç¨åºä¸å ³äºæ¯ä¸ªå¤æç±»çä¿¡æ¯ãç¼è¯å¨é常æé项ç¦ç¨æ¤ä¿¡æ¯ã
å ³é®è¯
示ä¾
è¿è¡æ¤ä»£ç
#include <iostream>  struct V { virtual void f() {}; // å¿ é¡»ä¸ºå¤æä»¥ä½¿ç¨è¿è¡æ¶æ£æ¥ç dynamic_cast }; struct A : virtual V {}; struct B : virtual V { B(V* v, A* a) { // æé ä¸è½¬åï¼è§åè¿° D çæé 彿°ä¸çè°ç¨ï¼ dynamic_cast<B*>(v); // è¯å¥½å®ä¹ï¼v æç±»å V*ï¼B ç V åºç±»ï¼äº§ç B* dynamic_cast<B*>(a); // æªå®ä¹è¡ä¸ºï¼a æç±»å A*ï¼A é B çåºç±» } }; struct D : A, B { D() : B((A*)this, this) { } };  struct Base { virtual ~Base() {} };  struct Derived: Base { virtual void name() {} };  int main() { D d; // æç»æ´¾ç对象 A& a = d; // åä¸è½¬åï¼å¯ä»¥ç¨ dynamic_castï¼ä½ä¸å¿ é¡» D& new_d = dynamic_cast<D&>(a); // åä¸è½¬å B& new_b = dynamic_cast<B&>(a); // ä¾§å转å   Base* b1 = new Base; if(Derived* d = dynamic_cast<Derived*>(b1)) { std::cout << "downcast from b1 to d successful\n"; d->name(); // å¯ä»¥å®å ¨è°ç¨ }  Base* b2 = new Derived; if(Derived* d = dynamic_cast<Derived*>(b2)) { std::cout << "downcast from b2 to d successful\n"; d->name(); // å¯ä»¥å®å ¨è°ç¨ }  delete b1; delete b2; }
è¾åºï¼
downcast from b2 to d successful