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++ è¯è¨ > reinterpret_cast 转æ¢
reinterpret_cast 转æ¢
éè¿éæ°è§£éåºå±ä½æ¨¡å¼å¨ç±»åé´è½¬æ¢ã
è¯æ³
reinterpret_cast < æ°ç±»å > ( è¡¨è¾¾å¼ )
|
|||||||||
è¿å æ°ç±»å ç±»åçå¼ã
è§£é
ä¸ static_cast ä¸åï¼ä½ä¸ const_cast 类似ï¼reinterpret_cast 表达å¼ä¸ä¼ç¼è¯æä»»ä½ CPU æä»¤ï¼é¤é卿´æ°åæéé´è½¬æ¢ï¼æå¨æé表示ä¾èµå ¶ç±»åçä¸ææ¶æä¸ï¼ãå®çº¯ç²¹æ¯ä¸ä¸ªç¼è¯æ¶æä»¤ï¼æç¤ºç¼è¯å¨å° è¡¨è¾¾å¼ è§ä¸ºå¦åå ·æ æ°ç±»å ç±»å䏿 ·å¤çã
坿ä¸å转æ¢è½ç¨ reinterpret_cast è¿è¡ï¼ä½è¥è½¬æ¢ä¼è½¬åèµ°å¸¸éæ§ææåæ§å亦ä¸å 许ã
è¡¨è¾¾å¼ çç¸åã(C++11 èµ·)T1* å¯è½¬æ¢ææå对象æéç±»å cv T2 ãè¿ä¸¥æ ¼çä»·äº static_cast<cv T2*>(static_cast<cv void*>(表达å¼))ï¼è¿æå³çï¼è¥ T2 ç对é½è¦æ±ä¸æ¯ T1 çæ´ä¸¥æ ¼ï¼åæéå¼ä¸æ¹åï¼ä¸å°ç»ææé转æ¢ååç±»åå°çæå
¶åå¼ï¼ã任使
åµä¸ï¼åªæç±»åå«ååï¼type aliasingï¼è§åå
许ï¼è§ä¸æï¼æ¶ï¼ç»ææéæå¯ä»¥å®å
¨å°è§£å¼ç¨T1 ç±»åçå·¦å¼è¡¨è¾¾å¼å¯è½¬æ¢æå°å¦ä¸ä¸ªç±»å T2 çå¼ç¨ãç»ææ¯ä¸å左弿代åä¸å¯¹è±¡ï¼ä½æä¸åç±»åçå·¦å¼æäº¡å¼ãä¸å建临æ¶éï¼ä¸è¿è¡å¤å¶ï¼ä¸è°ç¨æé 彿°æè½¬æ¢å½æ°ãåªæç±»åå«ååï¼type aliasingï¼è§åå
许ï¼è§ä¸æï¼æ¶ï¼ç»ææéæå¯ä»¥å®å
¨å°è§£å¼ç¨T1 çæå对象çæéå¯è½¬æ¢ææåå¦ä¸ä¸ªç±» T2 çå¦ä¸ä¸ªæå对象çæéãè¥ T2 ç对é½ä¸æ¯ T1 æ´ä¸¥æ ¼ï¼å转æ¢ååç±»å T1 å°çæåå¼ï¼å¦åä¸è½å®å
¨å°ä½¿ç¨ç»ææéãåææè½¬å表达å¼ï¼ç»ææ¯ï¼
- å·¦å¼ï¼è¥ new_type æ¯å·¦å¼å¼ç¨æå°å½æ°ç±»åçå³å¼å¼ç¨ï¼
- 亡å¼ï¼è¥ new_type æ¯å°å¯¹è±¡ç±»åçå³å¼å¼ç¨ï¼
- å¦å为纯å³å¼ã
å ³é®è¯
ç±»åå«åå
å¡å¨è¯å¾éè¿ AliasedType ç±»åçæ³å·¦å¼è¯»æä¿®æ¹ç±»å为 DynamicType ç对象ç弿¶ï¼è¡ä¸ºæªå®ä¹ï¼é¤éä¸åä¹ä¸ä¸ºçï¼
-
AliasedTypeä¸DynamicTypeç¸ä¼¼ã -
AliasedTypeæ¯DynamicTypeçï¼å¯æ cv éå®çï¼æç¬¦å·ææ 符å·åä½ã -
AliasedType为 std::byteã (C++17 èµ·)char æ unsigned charï¼è¿å®¹è®¸å°ä»»ä½å¯¹è±¡ç对象表示ä½ä¸ºä¸ä¸ªåèæ°ç»å 以æ£éªã
鿣å¼å°è¯´ï¼å¿½ç¥é¡¶å± cv é宿§ï¼è¥ä¸¤ä¸ªç±»å符åä¸åæ¡ä»¶ï¼åå®ä»¬ç¸ä¼¼ï¼
- å®ä»¬æ¯åä¸ç±»åï¼æ
- å®ä»¬é½æ¯æéï¼ä¸è¢«æåçç±»åç¸ä¼¼ï¼æ
- å®ä»¬é½æ¯æåç¸åç±»çæåæéï¼ä¸è¢«æåçæåç±»åç¸ä¼¼ï¼æ
|
(C++20 å) |
|
(C++20 èµ·) |
ä¾å¦ï¼
- const int * volatile * ä¸ int * * const ç¸ä¼¼ï¼
- const int (* volatile S::* const)[20] ä¸ int (* const S::* volatile)[20] ç¸ä¼¼ï¼
- int (* const *)(int *) ä¸ int (* volatile *)(int *) ç¸ä¼¼ï¼
- int (S::*)() const ä¸ int (S::*)() ä¸ç¸ä¼¼ï¼
- int (*)(int *) ä¸ int (*)(const int *) ä¸ç¸ä¼¼ï¼
- const int (*)(int *) ä¸ int (*)(int *) ä¸ç¸ä¼¼ï¼
- int (*)(int * const) ä¸ int (*)(int *) ç¸ä¼¼ï¼å®ä»¬æ¯åä¸ç±»åï¼ï¼
- std::pair<int, int> ä¸ std::pair<const int, int> ä¸ç¸ä¼¼ã
æ¤è§åå 许è¿è¡åºäºç±»åçå«ååæï¼å³ç¼è¯å¨å设éè¿ä¸ä¸ªç±»åçæ³å·¦å¼è¯»åçå¼ï¼ä¸ä¼è¢«éè¿ä¸åç±»åçæ³å·¦å¼çåå ¥æä¿®æ¹ï¼ä¾æ®ä¸è¿°ä¾å¤æ åµï¼ã
注æï¼è®¸å¤ C++ ç¼è¯å¨ä½ä¸ºéæ åè¯è¨æ©å±æ¾æ¾æ¤è§åï¼ä»¥å 许éè¿ union ç䏿´»è·æåçè¿è¡ç±»åé误ç访é®ï¼è¿ç§è®¿é®å¨ C ä¸å¹¶ä¸æ¯æªå®ä¹çï¼ã
注解
æ åä¸å®ä¹ä¸¥æ ¼å«ååè§åçæ®µè½å«æä¸¤æ¡é¢å¤æ¡ä¾ï¼é¨åå°æ¯ä» C ç»§æ¿èæ¥ï¼
-
AliasedType为èåç±»åæ union ç±»åï¼å®ä¿æåè¿°åç±»åä¹ä¸ä½ä¸ºå ¶å ç´ æééææåï¼éå½å°å å«åèåä½çå ç´ å被å å«çèåä½çééææ°æ®æåï¼ã -
AliasedType为DynamicTypeçï¼å¯æ cv éå®çï¼åºç±»ã
è¿äºæ¡ä¾ææè¿°çæ åµä¸å¯è½åºç°äº C++ï¼ä»èä»ä¸é¢ç讨论ä¸çç¥ãå¨ C ä¸ï¼èåå¤å¶åèµå¼å°èåä½å¯¹è±¡ä½ä¸ºæ´ä½è®¿é®ãä½ C++ ä¸å§ç»éè¿æå彿°è°ç¨è¿è¡è¿ç§è¡å¨ï¼è¿ä¼è®¿é®åç¬çå对象èéæ´ä¸ªå¯¹è±¡ï¼æå¨èåä½çæ åµä¸ï¼å¤å¶å¯¹è±¡è¡¨ç¤ºï¼å³ç»ç± unsigned charï¼ãè§æ ¸å¿é®é¢ 2051ã
å设符å对é½è¦æ±ï¼å reinterpret_cast å¨å¤çæéå¯äºè½¬æ¢å¯¹è±¡çå°æ°åéæ
åµå¤ï¼ä¸æ´æ¹æéçå¼ï¼
struct S1 { int a; } s1; struct S2 { int a; private: int b; } s2; // éæ åå¸å± union U { int a; double b; } u = {0}; int arr[2];  int* p1 = reinterpret_cast<int*>(&s1); // p1 çå¼ä¸ºâæå s1.a çæéâ // å 为 s1.a ä¸ s1 为æéå¯äºè½¬æ¢  int* p2 = reinterpret_cast<int*>(&s2); // reinterpret_cast 䏿´æ¹ p2 çå¼ä¸ºâæå s2 çæéâã  int* p3 = reinterpret_cast<int*>(&u); // p3 çå¼ä¸ºâæå u.a çæéâï¼u.a ä¸ u æéå¯äºè½¬æ¢  double* p4 = reinterpret_cast<double*>(p3); // p4 çæé为âæå u.b çæéâï¼u.a ä¸ u.b // æéå¯äºè½¬æ¢ï¼å 为é½ä¸ u æéå¯äºè½¬æ¢  int* p5 = reinterpret_cast<int*>(&arr); // reinterpret_cast 䏿´æ¹ p5 çå¼ä¸ºâæå arr çæéâ
å¨ä¸å®é
代表éå½ç±»åçå¯¹è±¡çæ³å·¦å¼ï¼ä¾å¦éè¿ reinterpret_cast æè·å¾ï¼ä¸ï¼è¿è¡ä»£è¡¨ééææ°æ®æåæééææå彿°çæå访é®ï¼å°å¯¼è´æªå®ä¹è¡ä¸ºï¼
struct S { int x; }; struct T { int x; int f(); }; struct S1 : S {}; // æ åå¸å± struct ST : S, T {}; // éæ åå¸å±  S s = {}; auto p = reinterpret_cast<T*>(&s); // p çå¼ä¸ºâæå s çæéâ auto i = p->x; // ç±»æå访é®è¡¨è¾¾å¼ä¸ºæªå®ä¹è¡ä¸ºï¼s 䏿¯ T 对象 p->x = 1; // æªå®ä¹è¡ä¸º p->f(); // æªå®ä¹è¡ä¸º  S1 s1 = {}; auto p1 = reinterpret_cast<S*>(&s1); // p1 çå¼ä¸ºâæå S ç s1 å对象çæéâ auto i = p1->x; // OK p1->x = 1; // OK  ST st = {}; auto p2 = reinterpret_cast<S*>(&st); // p2 çå¼ä¸ºâæå st çæéâ auto i = p2->x; // æªå®ä¹è¡ä¸º p2->x = 1; // æªå®ä¹è¡ä¸º
许å¤ç¼è¯å¨å¨è¿ç§æ åµä¸åå¸âä¸¥æ ¼å«ååâè¦åï¼å³ä½¿å¨ææ¯ä¸è¿ç§æé æè¿èçå¹¶é称为âä¸¥æ ¼å«ååè§åâæ®µè½çè§åã
ä¸¥æ ¼å«åååå ¶ç¸å ³è§åçç®çï¼æ¯å¯ç¨åºäºç±»åçå«ååæï¼è¥ç¨åºè½åæ³å°å建ä¸ç§æ å½¢ï¼ä½¿å¾ä¸¤ä¸ªæåæ å ³ç±»åçæéï¼ä¾å¦ä¸ä¸ª int* åä¸ä¸ª float*ï¼è½åæ¶åå¨å¹¶å¯ä¸åç¨äºå è½½æåå¨åä¸å åï¼è§æ¤ SG12 reflector ä¸çé®ä»¶ï¼ï¼åå«ååæä¼æ®éæ æãæ ä»»ä½çèµ·æ¥è½å¤å建è¿ç§æ å½¢çæå·§é½å¿ ç¶å¯¼è´æªå®ä¹è¡ä¸ºã
å½éè¦å°å¯¹è±¡çåèè§£é为ä¸åç±»åç弿¶ï¼å¯ä»¥ä½¿ç¨ std::memcpy æ std::bit_cast (C++20 èµ·)ï¼
double d = 0.1; std::int64_t n; static_assert(sizeof n == sizeof d); // n = *reinterpret_cast<std::int64_t*>(&d); // æªå®ä¹è¡ä¸º std::memcpy(&n, &d, sizeof d); // OK n = std::bit_cast<std::int64_t>(d); // 亦 OK
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| CWG 195 | C++98 | ä¸å è®¸å½æ°æéå对象æéé´çè½¬æ¢ | 使ä¹ä¸ºæ¡ä»¶æ§æ¯æ |
示ä¾
æ¼ç¤º reinterpret_cast çä¸äºç¨æ³ï¼
#include <cstdint> #include <cassert> #include <iostream> int f() { return 42; } int main() { int i = 7;  // æéå°æ´æ°å¹¶è½¬å std::uintptr_t v1 = reinterpret_cast<std::uintptr_t>(&i); // static_cast 为é误 std::cout << "The value of &i is 0x" << std::hex << v1 << '\n'; int* p1 = reinterpret_cast<int*>(v1); assert(p1 == &i);  // å°å¦ä¸å½æ°æé并转å void(*fp1)() = reinterpret_cast<void(*)()>(f); // fp1(); æªå®ä¹è¡ä¸º int(*fp2)() = reinterpret_cast<int(*)()>(fp1); std::cout << std::dec << fp2() << '\n'; // å®å ¨  // éè¿æéçç±»åå«åå char* p2 = reinterpret_cast<char*>(&i); if(p2[0] == '\x7') std::cout << "This system is little-endian\n"; else std::cout << "This system is big-endian\n";  // éè¿å¼ç¨çç±»åå«åå reinterpret_cast<unsigned int&>(i) = 42; std::cout << i << '\n';  [[maybe_unused]] const int &const_iref = i; // int &iref = reinterpret_cast<int&>(const_iref); // ç¼è¯é误ââä¸è½å»é¤ const // å¿ é¡»ç¨ const_cast 代æ¿ï¼int &iref = const_cast<int&>(const_iref); }
å¯è½çè¾åºï¼
The value of &i is 0x7fff352c3580 42 This system is little-endian 42
åé
| const_cast è½¬æ¢ | æ·»å æç§»é¤ const |
| static_cast è½¬æ¢ | è¿è¡åºæ¬è½¬æ¢ |
| dynamic_cast è½¬æ¢ | è¿è¡ææ£æ¥çå¤æè½¬æ¢ |
| æ¾å¼è½¬å | å¨ç±»åé´èªç±è½¬æ¢ |
| æ åè½¬æ¢ | ä»ä¸ä¸ªç±»åå°å¦ä¸ç±»åçéå¼è½¬æ¢ |