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++ è¯è¨ > æ¾å¼ï¼å ¨ï¼æ¨¡æ¿ç¹å
æ¾å¼ï¼å ¨ï¼æ¨¡æ¿ç¹å
å 许对ç»å®ç模æ¿å®åéå®å¶æ¨¡æ¿ä»£ç ã
è¯æ³
template <> 声æ
|
|||||||||
以ä¸ä»»ä½ä¸é¡¹åå¯ä»¥å®å ¨ç¹åï¼
- 彿°æ¨¡æ¿
- 类模æ¿
- (C++14 èµ·)å鿍¡æ¿
- 类模æ¿çæå彿°
- 类模æ¿çéææ°æ®æå
- 类模æ¿çæåç±»
- 类模æ¿çæåæä¸¾
- ç±»æç±»æ¨¡æ¿çæå类模æ¿
- ç±»æç±»æ¨¡æ¿çæå彿°æ¨¡æ¿
ä¾å¦ï¼
#include <iostream> template<typename T> // ä¸»æ¨¡æ¿ struct is_void : std::false_type { }; template<> // 对 T = void æ¾å¼ç¹å struct is_void<void> : std::true_type { }; int main() { // 对äºä»»ä½é void çç±»å Tï¼è¯¥ç±»åæ´¾çèª false_type std::cout << is_void<char>::value << '\n'; // ä½å½ T 为 void æ¶ç±»æ´¾çèª true_type std::cout << is_void<void>::value << '\n'; }
ç»è
æ¾å¼ç¹åå¯ä»¥å¨å¯ä»¥å®ä¹å ¶ä¸»æ¨¡æ¿çä»»ä½ä½ç¨åä¸å£°æï¼è¿å¯ä»¥ä¸åäºå®ä¹å ¶ä¸»æ¨¡æ¿å®ä¹çä½ç¨åï¼ä¾å¦åæå模æ¿çç±»å¤ç¹åï¼ãæ¾å¼ç¹åå¿ é¡»åºç°å¨éç¹å模æ¿å£°æåã
namespace N { template<class T> class X { /*...*/ }; // ä¸»æ¨¡æ¿ template<> class X<int> { /*...*/ }; // åå½å空é´ä¸çç¹å  template<class T> class Y { /*...*/ }; // ä¸»æ¨¡æ¿ template<> class Y<double>; // 对 double ç¹åçå置声æ } template<> class N::Y<double> { /*...*/ }; // OKï¼åå½å空é´ä¸çç¹å
ç¹åå¿ é¡»å¨ç¬¬ä¸æ¡å¯¼è´éå¼å®ä¾åç使ç¨ä¹åï¼å¨æ¯ä¸ªåçè¿ç§ä½¿ç¨çç¿»è¯åå ä¸å£°æï¼
class String {}; template<class T> class Array { /*...*/ }; template<class T> void sort(Array<T>& v) { /*...*/ } // ä¸»æ¨¡æ¿ Â void f(Array<String>& v) { sort(v); // éå¼å®ä¾å sort(Array<String>&), } // 使ç¨åçæ¨¡æ¿ sort()  template<> // é误ï¼sort(Array<String>) çæ¾å¼ç¹ååºç°å¨éå¼å®ä¾åä¹å void sort<String>(Array<String>& v);
ä» å£°æä½æªå®ä¹ç模æ¿ç¹åï¼å¯åå ¶ä»ä¸å®æ´ç±»å䏿 ·ä½¿ç¨ï¼ä¾å¦å¯ä»¥ä½¿ç¨å°å®çæéåå¼ç¨ï¼
template<class T> class X; // ä¸»æ¨¡æ¿ template<> class X<int>; // ç¹åï¼å£°æï¼ä¸å®ä¹ï¼ X<int>* p; // OKï¼æåä¸å®æ´ç±»åçæé X<int> x; // é误ï¼ä¸å®æ´ç±»åç对象
彿°æ¨¡æ¿çæ¾å¼ç¹å
å½ç¹å彿°æ¨¡æ¿æ¶ï¼è¥æ¨¡æ¿å®åæ¨å¯¼è½ä»å½æ°å®åäºä»¥æä¾ï¼åå¯å¿½ç¥å ¶å®åï¼
template<class T> class Array { /*...*/ }; template<class T> void sort(Array<T>& v); // ä¸»æ¨¡æ¿ template<> void sort(Array<int>&); // 对 T = int çç¹å // ä¸éè¦å为 // template<> void sort<int>(Array<int>&);
ä¸æä¸ªç¹å带æç¸ååååç¸åå½¢åå表ç彿°ä¸æ¯ç¹åï¼è§å½æ°æ¨¡æ¿ä¸çéè½½ï¼
ä» å½å½æ°æ¨¡æ¿çæ¾å¼ç¹å声æä¸ºå¸¦ inline 说æç¬¦ï¼æå®ä¹ä¸ºå¼ç½®ï¼æ¶ï¼å®æ¯å è彿°ï¼ä¸»æ¨¡æ¿æ¯å¦ä¸ºå èå¯¹å ¶æ²¡æå½±åã
ä¸è½å¨å½æ°æ¨¡æ¿ï¼æå彿°æ¨¡æ¿ï¼ä»¥åå¨éå¼å®ä¾åç±»æ¶ç类模æ¿çæå彿°çæ¾å¼ç¹å䏿å®é»è®¤å½æ°å®åã
æ¾å¼ç¹åä¸è½æ¯åå 声æã
è¥ä¸»æ¨¡æ¿å
·æå¹¶é noexcept(false) çå¼å¸¸è¯´æï¼åæ¾å¼ç¹åå¿
é¡»å
·æå
¼å®¹çå¼å¸¸è¯´æã
ç¹åçæå
å¨ç±»ä½å¤å®ä¹æ¾å¼ç¹åç类模æ¿çæåæ¶ï¼ä¸ä½¿ç¨ template <> è¯æ³ï¼é¤é宿¯æä¸ªè¢«ç¹å为类模æ¿çæ¾å¼ç¹åçæå类模æ¿çæåï¼å ä¸ºå ¶ä»æ åµä¸ï¼è¯æ³ä¼è¦æ±è¿ç§å®ä¹ä»¥åµå¥æ¨¡æ¿æè¦æ±ç template<å½¢å> å¼å§
template< typename T> struct A { struct B {}; // æåç±» template<class U> struct C { }; // æåç±»æ¨¡æ¿ };  template<> // ç¹å struct A<int> { void f(int); // ç¹åçæå彿° }; // template<> ä¸ç¨äºç¹åçæå void A<int>::f(int) { /* ... */ }  template<> // æåç±»çç¹å struct A<char>::B { void f(); }; // template<> 亦ä¸ç¨äºç¹åçæåç±»çæå void A<char>::B::f() { /* ... */ }  template<> // æå类模æ¿ççå®ä¹ template<class U> struct A<char>::C { void f(); };  // template<> å¨ä½ä¸ºç±»æ¨¡æ¿å®ä¹æ¾å¼ç¹åçæåç±»æ¨¡æ¿æ¶ä½¿ç¨ template<> template<class U> void A<char>::C<U>::f() { /* ... */ }
模æ¿çéææ°æ®æåçæ¾å¼ç¹åï¼è¥å
¶å£°æå
å«åå§åå¨å为å®ä¹ï¼å¦åï¼å®æ¯å£°æãè¿äºå®ä¹å¯¹äºé»è®¤åå§åå¿
é¡»ç¨è±æ¬å·ï¼
template<> X Q<int>::x; // éææåç声æ template<> X Q<int>::x (); // é误ï¼å½æ°å£°æ template<> X Q<int>::x {}; // éææåçé»è®¤åå§åå®ä¹
类模æ¿çæåææå模æ¿å¯å¯¹äºç±»æ¨¡æ¿çéå¼å®ä¾åæ¾å¼ç¹åï¼å³ä½¿æåææå模æ¿å®ä¹äºç±»æ¨¡æ¿å®ä¹ä¸ã
template<typename T> struct A { void f(T); // æåï¼å£°æäºä¸»æ¨¡æ¿ä¸ void h(T) {} // æåï¼å®ä¹äºä¸»æ¨¡æ¿ä¸ template<class X1> void g1(T, X1); // æåæ¨¡æ¿ template<class X2> void g2(T, X2); // æåæ¨¡æ¿ };  // æåçç¹å template<> void A<int>::f(int); // æåç¹å OKï¼å³ä½¿å®ä¹äºç±»ä¸ template<> void A<int>::h(int) {}  // ç±»å¤æåæ¨¡æ¿å®ä¹ template<class T> template<class X1> void A<T>::g1(T, X1) { }  // æå模æ¿ç¹å template<> template<class X1> void A<int>::g1(int, X1);  // æå模æ¿ç¹å template<> template<> void A<int>::g2<char>(int, char); // å¯¹äº X2 = char // åä¸ï¼ç¨æ¨¡æ¿å®åæ¨å¯¼ (X1 = char) template<> template<> void A<int>::g1(int, char);
æåææå模æ¿å¯åµå¥äºå¤ä¸ªå¤å´ç±»æ¨¡æ¿ä¸ãå¨è¿ç§æåçæ¾å¼ç¹åä¸ï¼å¯¹æ¯ä¸ªæ¾å¼ç¹åçå¤å´ç±»æ¨¡æ¿é½æä¸ä¸ª template<>ã
template<class T1> class A { template<class T2> class B { void mf(); }; }; template<> template<> class A<int>::B<double>; template<> template<> void A<char>::B<char>::mf();
å¨è¿ç§åµå¥å£°æä¸ï¼æäºå±æ¬¡å¯ä¿çä¸ç¹åï¼ä½è¥å ¶å¤å´ç±»æªè¢«ç¹åï¼åä¸è½ç¹åç±»æå模æ¿ï¼ãå¯¹äºæ¯ä¸ªè¿ç§å±æ¬¡ï¼å£°æéè¦ template<å®å>ï¼å 为è¿ç§ç¹åèªèº«ä¹æ¯æ¨¡æ¿ï¼
template <class T1> class A { template<class T2> class B { template<class T3> void mf1(T3); // æåæ¨¡æ¿ void mf2(); // 鿍¡æ¿æå }; };  // ç¹å template<> // 对äºç¹åç A template<class X> // å¯¹äºæªç¹åç B class A<int>::B { template <class T> void mf1(T); };  // ç¹å template<> // 对äºç¹åç A template<> // 对äºç¹åç B template<class T> // å¯¹äºæªç¹åç mf1 void A<int>::B<double>::mf1(T t) { }  // é误ï¼B<double> 被ç¹åè䏿¯æå模æ¿ï¼æ å ¶å¤å´ç A ä¹å¿ é¡»ç¹å template<class Y> template<> void A<Y>::B<double>::mf2() { }
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| CWG 727 | C++14 | ä¸å 许å¨ç±»ä½ç¨åçå ¨ç¹åï¼å³ä½¿å 许é¨åç¹å | å 许å¨ä»»ä½ä½ç¨åçå ¨ç¹å |