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++17 èµ·)
ç»æåç»å®å£°æ (C++17 èµ·)
ç»å®æå®åç§°å°åå§åå¨çå对象æå ç´ ã
类似å¼ç¨ï¼ç»æåç»å®æ¯æ¢å对象çå«åãä¸åäºå¼ç¨çæ¯ï¼ç»æåç»å®çç±»åä¸å¿ 为å¼ç¨ç±»åã
attr(å¯é) cv-auto ref-è¿ç®ç¬¦(å¯é) [ æ è¯ç¬¦å表 ] = è¡¨è¾¾å¼ ;
|
(1) | ||||||||
attr(å¯é) cv-auto ref-è¿ç®ç¬¦(å¯é) [ æ è¯ç¬¦å表 ] { è¡¨è¾¾å¼ } ;
|
(2) | ||||||||
attr(å¯é) cv-auto ref-è¿ç®ç¬¦(å¯é) [ æ è¯ç¬¦å表 ] ( è¡¨è¾¾å¼ ) ;
|
(3) | ||||||||
| attr | - | ä»»ææ°éç屿§çåºå |
| cv-auto | - | 坿 cv éå®ç auto ç±»å说æç¬¦ï¼äº¦å¯å
å«åå¨ç±»è¯´æç¬¦ static æ thread_local ï¼å¨ cv éå®ç¬¦ä¸å
å« volatile æ¯è¢«å¼ç¨ç (C++20 èµ·)
|
| ref-è¿ç®ç¬¦ | - | & æ && ä¹ä¸
|
| æ è¯ç¬¦å表 | - | æ¤å£°ææå¼å ¥çåæ è¯ç¬¦çéå·åéçå表 |
| è¡¨è¾¾å¼ | - | 顶屿²¡æéå·è¿ç®ç¬¦ç表达å¼ï¼ææ³ä¸ä¸ºèµå¼è¡¨è¾¾å¼ï¼ï¼ä¸å ·ææ°ç»æéèåç±»ä¹ä¸çç±»åãè¥ è¡¨è¾¾å¼ æ¶å任使¥èª æ è¯ç¬¦å表 çååï¼å声æéè¯æã |
ç»æåç»å®å£°æå° æ è¯ç¬¦å表 ä¸çæææ è¯ç¬¦ï¼å¼å ¥ä½ä¸ºå ¶å¤å´ä½ç¨åä¸çååï¼å¹¶å°å®ä»¬ç»å®å° è¡¨è¾¾å¼ ææä»£ç对象çå个å对象æå ç´ ãä»¥æ¤æ¹å¼å¼å ¥çç»å®è¢«ç§°ä½ç»æåç»å®ã
ç»æåç»å®å£°æé¦å
å¼å
¥ä¸ä¸ªå¯ä¸å½åçåéï¼æ¤å¤ä»¥ e æä»£ï¼æ¥ä¿æå
¶åå§åå¨çå¼ï¼æ¹å¼å¦ä¸ï¼
- è¥ è¡¨è¾¾å¼ å
·ææ°ç»ç±»å
Aä¸ä¸åå¨ ref-è¿ç®ç¬¦ï¼åeå ·æç±»å cvAï¼å ¶ä¸ cv æ¯ cv-auto åºåä¸ç cv éå®ç¬¦ï¼ä¸eçå个å ç´ ä» è¡¨è¾¾å¼ ç对åºå ç´ è¿è¡å¤å¶ï¼å¯¹äº (1)ï¼æç´æ¥ï¼å¯¹äº (2,3)ï¼åå§åã - å¦å
eå¦åäºå£°æä¸ä»¥å ¶åå代[æ è¯ç¬¦å表]ä¸è¬å®ä¹ã
æä»¬ç¨ E ä»£è¡¨è¡¨è¾¾å¼ e çç±»åãï¼æ¢è¨ä¹ï¼E çä»·äº std::remove_reference_t<decltype((e))>ï¼ã
ç¶åï¼ç»æåç»å®ä»¥ä¸ç§å¯è½æ¹å¼ä¹ä¸è¿è¡ç»å®ï¼åå³äº Eï¼
- æ
åµ 1ï¼è¥
Eæ¯æ°ç»ç±»åï¼åç»å®å个ååå°å个æ°ç»å ç´ ã - æ
åµ 2ï¼è¥
Eæ¯éèå类类åä¸ std::tuple_size<E> æ¯å®æ´ç±»åï¼å使ç¨âå ç»å¼âç»å®åè®®ã - æ
åµ 3ï¼è¥
Eæ¯éèå类类åä½ std::tuple_size<E> 䏿¯å®æ´ç±»åï¼åç»å®å个ååå°Eçå个å¯è®¿é®æ°æ®æåã
ä¸ç§æ åµçæ¯ä¸ç§ï¼ä¸æä¸é½ææ´è¯¦ç»çæè¿°ã
æ¯ä¸ªç»æåç»å®é½æä¸ä¸ªè¢«å¼ç¨ç±»åï¼å¨åæçæè¿°ä¸å®ä¹ãæ¤ç±»åæ¯å¯¹æ æ¬å·çç»æåç»å®åºç¨ decltype æè¿åçç±»åã
æ åµ 1ï¼ç»å®æ°ç»
æ è¯ç¬¦å表 ä¸çæ¯ä¸ªæ è¯ç¬¦åæä¸ºæä»£æ°ç»ç对åºå ç´ çå·¦å¼ãæ è¯ç¬¦çæ°éå¿ é¡»çäºæ°ç»çå ç´ æ°éã
æ¯ä¸ªæ è¯ç¬¦ç被å¼ç¨ç±»å齿¯æ°ç»çå
ç´ ç±»åãæ³¨æè¥æ°ç»ç±»å E 为 cv éå®çï¼åå
¶å
ç´ äº¦ç¶ã
int a[2] = {1,2};  auto [x,y] = a; // å建 e[2]ï¼å¤å¶ a å° eï¼ç¶å x æä»£ e[0]ï¼y æä»£ e[1] auto& [xr, yr] = a; // xr æä»£ a[0]ï¼yr æä»£ a[1]
æ åµ 2ï¼ç»å®å ç»å¼ç±»å
è¡¨è¾¾å¼ std::tuple_size<E>::value å¿ é¡»æ¯è¯æçæ´æ°å¸¸é表达å¼ï¼ä¸æ è¯ç¬¦çæ°éå¿ é¡»çäº std::tuple_size<E>::valueã
å¯¹äºæ¯ä¸ªæ è¯ç¬¦ï¼å¼å ¥ä¸ä¸ªç±»å为âstd::tuple_element<i, E>::type çå¼ç¨âçåéï¼è¥å ¶å¯¹åºåå§å卿¯å·¦å¼ï¼å为左å¼å¼ç¨ï¼å¦å为å³å¼å¼ç¨ã第 i 个åéçåå§åå¨
- è¥å¨
Eçä½ç¨åä¸å¯¹æ è¯ç¬¦getæç±»æå访é®è¿è¡çæ¥æ¾ä¸ï¼è³å°æ¾å°ä¸ä¸ªå£°ææ¯é¦ä¸ªæ¨¡æ¿å½¢å为éç±»åå½¢åç彿°æ¨¡æ¿ï¼å为 e.get<i>() - å¦å为 get<i>(e)ï¼å ¶ä¸ get åªè¿è¡å®åä¾èµæ¥æ¾ï¼å¿½ç¥é ADL çæ¥æ¾ã
è¿äºåå§åå¨è¡¨è¾¾å¼ä¸ï¼è¥å®ä½ e çç±»å为左å¼å¼ç¨ï¼è¿ä»
å¨ ref-è¿ç®ç¬¦ 为 &ï¼æä¸º && ä¸åå§åå¨ä¸ºå·¦å¼æ¶æåçï¼ï¼å e 为左å¼ï¼å¦å为亡å¼ï¼è¿å®é
ä¸è¿è¡äºä¸ç§å®ç¾è½¬åï¼ï¼i æ¯ std::size_t ç纯å³å¼ï¼èä¸å§ç»å° <i> è§£é为模æ¿å½¢åå表ã
å鿥æä¸ e ç¸åçå卿ã
ç¶å该æ è¯ç¬¦åææä»£ä¸ä¸è¿°åéç»å®ç对象çå·¦å¼ã
第 i 个æ è¯ç¬¦ç被å¼ç¨ç±»å为 std::tuple_element<i, E>::typeã
float x{}; char y{}; int z{};  std::tuple<float&,char&&,int> tpl(x,std::move(y),z); const auto& [a,b,c] = tpl; // a æåæä»£ x çç»æåç»å®ï¼decltype(a) 为 float& // b æåæä»£ y çç»æåç»å®ï¼decltype(b) 为 char&& // c æåæä»£ tpl ç第 3 å ç´ çç»æåç»å®ï¼decltype(c) 为 const int
æ åµ 3ï¼ç»å®å°æ°æ®æå
E çææééææ°æ®æåå¿
须齿¯ E æ E çåä¸åºç±»çç´æ¥æåï¼å¿
须卿å为 e.name æ¶äºç»æåç»å®çè¯å¢ä¸æ¯è¯æçãE ä¸è½æå¿åèå使åãæ è¯ç¬¦çæ°éå¿
é¡»çäºééææ°æ®æåçæ°éã
æ è¯ç¬¦å表 ä¸çå个æ è¯ç¬¦ï¼æå£°æé¡ºåºä¾æ¬¡æä¸ºæä»£ e çå个æåçå·¦å¼çååï¼æ¯æä½åï¼ï¼å·¦å¼çç±»åæ¯ cv T_iï¼å
¶ä¸ cv æ¯ E ç cv éå®ç¬¦ä¸ T_i æ¯ç¬¬ i 个æåç声æç±»åã
第 i 个æ è¯ç¬¦ç被å¼ç¨ç±»åæ¯ cv T_iã
struct S { int x1 : 2; volatile double y1; }; S f();  const auto [x, y] = f(); // x æ¯æ è¯ 2 ä½ä½åç const int å·¦å¼ // y æ¯ const volatile double å·¦å¼
注解
对æå get çæ¥æ¾ç
§å¸¸å¿½ç¥å¯è®¿é®æ§ï¼äº¦å¿½ç¥éç±»åæ¨¡æ¿å½¢åçç¡®åç±»åãåºç°ç§æç template<char*> void get(); æåå°å¯¼è´ä½¿ç¨æåè§£éæ¹æ¡ï¼å³ä¾¿éè¯æä¹æ¯å¦æ¤ã
声æä¸ [ ä¹åçé¨ååºç¨äºéèåé eï¼èéå¼å
¥çå个æ è¯ç¬¦ã
è¥ std::tuple_size<E> æ¯å®æ´ç±»åï¼åå§ç»ä½¿ç¨å ç»å¼è§£éæ¹æ¡ï¼å³ä½¿å¯¼è´ç¨åºéè¯æä¹æ¯å¦æ¤ï¼
struct A { int x; }; namespace std { template<> struct tuple_size<::A> {}; }  auto [x] = A{}; // é误ï¼ä¸èèâæ°æ®æåâè§£éæ¹æ¡ã
è¥åå¨ ref-è¿ç®ç¬¦ ä¸ è¡¨è¾¾å¼ ä¸ºçº¯å³å¼ï¼ååºç¨å°å¼ç¨ç»å®å°ä¸´æ¶éçé常è§åï¼å
æ¬çåæå»¶ç»ï¼ãè¿äºæ
åµä¸ï¼éèåé e æ¯ç»å®å°ä»çº¯å³å¼è¡¨è¾¾å¼å®è´¨åç临æ¶åéï¼å¹¶å»¶é¿å
¶çåæçä¸ä¸ªå¼ç¨ãå¦å¾å¸¸æ
åµï¼è¥ e æ¯é const å·¦å¼å¼ç¨ï¼åç»å®å¤±è´¥ï¼
int a = 1; const auto& [x] = std::make_tuple(a); // OKï¼éæ¬åå¼ç¨ auto& [y] = std::make_tuple(a); // é误ï¼ä¸è½ç»å® auto& å°å³å¼ std::tuple auto&& [z] = std::make_tuple(a); // 亦 OK
decltype(x) æåç»æåç»å®ç被å¼ç¨ç±»åï¼å
¶ä¸ x 代表ä¸ä¸ªç»æåç»å®ãå¨å
ç»å¼çæ
åµä¸ï¼å®æ¯ std::tuple_element æè¿åçç±»åï¼å®å¯è½ä¸æ¯å¼ç¨ï¼å³ä½¿å¨æ¤æ
åµä¸ç»æåç»å®èªèº«å®é
ä¸å§ç»è¡¨ç°ä¸ºç±»ä¼¼å¼ç¨ãè¿ç¸å½äºæ¨¡æäºç»å®å°å
¶å个ééææ°æ®æåå
·æ tuple_element æè¿åçç±»åçç»æä½çè¡ä¸ºï¼èç»å®èªèº«çå¼ç¨æ§è´¨åä»
æ¯å®ç°ç»èã
std::tuple<int, int&> f();  auto [x, y] = f(); // decltype(x) 为 int // decltype(y) 为 int&  const auto [z, w] = f(); // decltype(z) 为 const int // decltype(w) 为 int&
示ä¾
#include <set> #include <string> #include <iomanip> #include <iostream> Â int main() { std::set<std::string> myset; if (auto [iter, success] = myset.insert("Hello"); success) std::cout << "insert is successful. The value is " << std::quoted(*iter) << '\n'; else std::cout << "The value " << std::quoted(*iter) << " already exists in the set\n"; }
è¾åºï¼
insert is successful. The value is "Hello"
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| P0961R1 | C++17 | å
ç»å¼æ
åµä¸ï¼è¥æ¥æ¾æ¾å°ä»»ä½ç±»åç get åä½¿ç¨æå get
|
ä» è¥æ¥æ¾æ¾å°æ¥æéç±»åæ¨¡æ¿å½¢åç彿°æ¨¡æ¿æä½¿ç¨ |
| P0969R0 | C++17 | ç»å®å°æåæ åµä¸ï¼è¦æ±æåä¸ºå ¬å¼ | ä» è¦æ±å¨å£°æçè¯å¢ä¸å¯è®¿é® |
åé
å建左å¼å¼ç¨ç tupleï¼æå° tuple è§£å
为ç¬ç«å¯¹è±¡ (彿°æ¨¡æ¿) |