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++ è¯è¨ > æªå®ä¹è¡ä¸º
æªå®ä¹è¡ä¸º
è¥è¿åæäºè§åï¼å令æ´ä¸ªç¨åºå¤±å»æä¹ã
è§£é
C++ æ å为ä¸è¢«å½å ¥ä¸ååç±»ä¹ä¸çæ¯ä¸ªç¨åºé½ç²¾ç¡®å®ä¹äºå ¶å¯è§å¯è¡ä¸ºï¼
- éè¯æï¼ill-formedï¼ââç¨åºæ¥æè¯æ³é误æå¯è¯æçè¯ä¹é误ãéµä»æ åç C++ ç¼è¯å¨å¿ 须为æ¤ç»åºè¯æï¼å³ä½¿å®å®ä¹äºä¸ºè¿ç§ä»£ç èµäºäºå«ä¹çè¯è¨æ©å±ï¼ä¾å¦ç¨é常éé¿åº¦æ°ç»ï¼ä¹åºå¦æ¤ãæ åææ¬ç¨ shallï¼åºå½ï¼ã shall notï¼ä¸åºå½ï¼å ill-formedï¼éè¯æï¼ç»åºäºè¿äºè¦æ±ã
- éè¯æèä¸è¦æ±è¯æï¼ill-formed no diagnostic requiredï¼ââç¨åºæ¥æé常æ åµä¸å¯è½æ æ³è¯æçè¯ä¹é误ï¼ä¾å¦ ODR çè¿è§æè å ¶ä»åªè½å¨è¿æ¥æ¶æ£æµçé误ï¼ãè¥æ§è¡è¿ç§ç¨åºåè¡ä¸ºæªå®ä¹ã
- ç±å®ç°å®ä¹çè¡ä¸ºï¼implementation-defined behaviorï¼ââç¨åºçè¡ä¸ºéå®ç°èåå¨ï¼éµä»æ åçå®ç°å¿ 须为æ¯ä¸ªè¿æ ·çè¡ä¸ºçæææä¾ææ¡£ãä¾å¦ std::size_t çç±»åæåèä¸ç使°ï¼æè std::bad_alloc::what çææ¬ãç±å®ç°å®ä¹çè¡ä¸ºçä¸ä¸ªå鿝æ¬å°ç¯å¢ç¹å®è¡ä¸ºï¼locale-specific behaviorï¼ï¼å®åå³äºå®ç°ææä¾çæ¬å°ç¯å¢ã
- æªææçè¡ä¸ºï¼ unspecified behavior ï¼ââç¨åºçè¡ä¸ºéå®ç°èåå¨ï¼èä¸è¦æ±éµä»æ åçå®ç°ä¸ºæ¯ä¸ªè¡ä¸ºçæææä¾ææ¡£ãä¾å¦æ±å¼é¡ºåºï¼çåçå符串åé¢éæ¯å¦ä¸ºç¸å¼å¯¹è±¡ï¼æ°ç»åé çå¼éï¼ççãæ¯ä¸ªæªææè¡ä¸ºå产çåæ³ç»æéåä¸çä¸ä¸ªç»æã
- æªå®ä¹è¡ä¸ºï¼undefined behaviorï¼UBï¼ââ对ç¨åºçè¡ä¸ºæ ä»»ä½éå¶ãæªå®ä¹è¡ä¸ºçä¾åæ¯æ°ç»è¾¹çå¤çå å访é®ï¼æç¬¦å·æ´æ°æº¢åºï¼ç©ºæéçè§£å¼ç¨ï¼å¨è¡¨è¾¾å¼ä¸å¯¹å䏿 éå¤äºä¸æ¬¡çä¸é´æ åºåç¹ (C++11 å)æ åº (C++11 èµ·)çä¿®æ¹ï¼éè¿ä¸åç±»åçæé访é®å¯¹è±¡ï¼ççãä¸è¦æ±ç¼è¯å¨è¯ææªå®ä¹è¡ä¸ºï¼å°½ç®¡è®¸å¤ç®åæ 形确å®ä¼å¾å°è¯æï¼ï¼èä¸ä¸è¦æ±æç¼è¯çç¨åºå任使æä¹çäºã
UB ä¸ä¼å
å 为æ£ç¡®ç C++ ç¨åºä¸å«æªå®ä¹è¡ä¸ºï¼æ å¨å¯ç¨ä¼åé项以ç¼è¯ç¡®å®å«æ UB çç¨åºæ¶ï¼ç¼è¯å¨å¯è½äº§çä¸æå¾ çç»æï¼
ä¾å¦ï¼
æç¬¦å·æº¢åº
int foo(int x) { return x+1 > x; // è¦ä¹ä¸º true è¦ä¹å æç¬¦å·æº¢åºèè´ UB }
å¯ç¼è¯ä¸ºï¼æ¼ç¤ºï¼
foo(int): movl $1, %eax ret
è¾¹çå¤è®¿é®
int table[4] = {}; bool exists_in_table(int v) { // å¨å¤´ 4 次è¿ä»£ä¸è¿å trueï¼æå è¾¹çå¤è®¿é®èè´ UB for (int i = 0; i <= 4; i++) { if (table[i] == v) return true; } return false; }
å¯è½ç¼è¯ä¸ºï¼æ¼ç¤ºï¼
exists_in_table(int): movl $1, %eax ret
æªåå§åæ é
std::size_t f(int x) { std::size_t a; if(x) // x éé¶æ UB a = 42; return a; }
å¯è½ç¼è¯ä¸ºï¼æ¼ç¤ºï¼
f(int): mov eax, 42 ret
以ä¸ç»åºçè¾åºæ¾å¨æ§çæ¬ gcc ä¸è§å¯å°
è¿è¡æ¤ä»£ç
å¯è½çè¾åºï¼
p is true p is false
éæ³æ é
int f() { bool b = true; unsigned char* p = reinterpret_cast<unsigned char*>(&b); *p = 10; // ä» b 读åç°å¨æ¯ UB return b == 0; }
å¯ç¼è¯æï¼æ¼ç¤ºï¼
f(): movl $11, %eax ret
空æéè§£å¼ç¨
int foo(int* p) { int x = *p; if(!p) return x; // è¦ä¹å¦ä¸äº§ç UBï¼è¦ä¹ä¸å¯è½éç¨æ¤åæ¯ else return 0; } int bar() { int* p = nullptr; return *p; // æ æ¡ä»¶ UB }
å¯è½ç¼è¯ä¸ºï¼ foo ç¨ gcc ã bar ç¨ clang ï¼
foo(int*): xorl %eax, %eax ret bar(): retq
访é®å·²ä¼ éç» realloc çæé
éæ© clang 以è§å¯æç¤ºè¾åº
è¿è¡æ¤ä»£ç
#include <iostream> #include <cstdlib> int main() { int *p = (int*)std::malloc(sizeof(int)); int *q = (int*)std::realloc(p, sizeof(int)); *p = 1; // UB ï¼è®¿é®ä¼ éç» realloc çæé *q = 2; if (p == q) // UB ï¼è®¿é®ä¼ éç» realloc çæé std::cout << *p << *q << '\n'; }
å¯è½çè¾åºï¼
12
æ å¯ä½ç¨çæ é循ç¯
éæ© clang 以è§å¯æç¤ºè¾åº
è¿è¡æ¤ä»£ç
#include <iostream>  int fermat() { const int MAX = 1000; int a=1,b=1,c=1; // æ å¯ä½ç¨çæ éå¾ªç¯æ¯ UB while (1) { if (((a*a*a) == ((b*b*b)+(c*c*c)))) return 1; a++; if (a>MAX) { a=1; b++; } if (b>MAX) { b=1; c++; } if (c>MAX) { c=1;} } return 0; }  int main() { if (fermat()) std::cout << "Fermat's Last Theorem has been disproved.\n"; else std::cout << "Fermat's Last Theorem has not been disproved.\n"; }
å¯è½çè¾åºï¼
Fermat's Last Theorem has been disproved.
å¤é¨é¾æ¥
- æ¯ä¸ª C ç¨åºåé½è¯¥ç¥éå ³äºæªå®ä¹è¡ä¸ºçäº #1/3
- æ¯ä¸ª C ç¨åºåé½è¯¥ç¥éå ³äºæªå®ä¹è¡ä¸ºçäº #2/3
- æ¯ä¸ª C ç¨åºåé½è¯¥ç¥éå ³äºæªå®ä¹è¡ä¸ºçäº #3/3
- æªå®ä¹è¡ä¸ºè½å¯¼è´æ¶é´æ è¡ï¼å¨ææäºé¡¹ä¸ï¼æ¶é´æ è¡å¯æ¯ææäººçï¼
- äºè§£ C/C++ ä¸çæ´æ°æº¢åº
- æªå®ä¹è¡ä¸ºä¸è´¹é©¬æåå®ç
- 空æéçè¶£äºï¼ç¬¬ä¸é¨å ï¼ Linux 2.6.30 ä¸ç©ºæéè§£å¼ç¨æè´çæªå®ä¹è¡ä¸ºæå¼åçå±é¨æ»¥ç¨ï¼