個人觀點:今天有幸看到各位大神們在討論constexpr的前途,有人說vs20十、20十一、20十二、2013都不支持,因此就以爲沒用。好吧,個人世界中vs並非不可獲取,好吧,本身爲了口頭的勝利開始胡扯了。constexpr就像是一個告訴編譯器,this is a const XXtype.可是各類有趣的實驗證實了這個玩意仍是有用的。html
我來給大家驗證一下:ios
1.如數一個數字,計算出它的!的結果(忘記叫什麼了eg:5!==5*4*3*2*1==120)api
1 //build-1234-Desktop_Qt_5_3_MinGW_32bit-Debug 2 #include <iostream> 3 constexpr int fact(int n) 4 { 5 return n<2?1:(n*fact(n-1)); 6 } 7 constexpr int fact2(int n){ 8 return n<2?1:(n*fact(n-1)); 9 } 10 template<int n>class print{ 11 public: 12 print(){std::cout<<n<<'\t';} 13 }; 14 int main() 15 { 16 std::cout<<fact(5)<<'\t'<<fact2(6)<<std::endl; 17 print<fact(5)> out1; 18 print<fact2(6)> out2; 19 return 0; 20 } 21 //output 22 /** 23 120 720 24 120 720 25 */
本例也就是constexpr最基本的功能,可使一個函數轉化成一個基本類型同樣的類型。使C++看起來更加完善函數
甚至能夠把上面的例子中修改成print(){std::cout<<(char)n<<'\t';}ui
二、能夠用在一些不須要修改的地方,防止修改。(const)this
1 //build-1234-Desktop_Qt_5_3_MinGW_32bit-Debug 2 #include <iostream> 3 #include <stdexcept> 4 5 class conststr{//定義一個const string類 6 const char* p; 7 std::size_t N; 8 public: 9 template<std::size_t Num> 10 constexpr conststr(const char(&a)[Num]):p(a),N(Num-1){} 11 constexpr char operator[](std::size_t n){//後面有用 12 return n<N?p[n]:throw std::out_of_range(""); 13 } 14 constexpr std::size_t size(){ 15 return N; 16 } 17 }; 18 constexpr std::size_t countlower(conststr s,std::size_t c=0,std::size_t n=0){//計算'a'<X>'z' 19 return n==s.size()?c: 20 s[n]>='a'&& s[n]<='z'? 21 countlower(s,c+1,n+1):countlower(s,c,n+1); 22 } 23 24 int main() 25 { 26 std::cout<<countlower("hello,world")<<std::endl; 27 std::cout<<countlower("hello,world___and___it")<<std::endl; 28 return 0; 29 } 30 //output 31 /** 32 10 33 15 34 */
本文參考地方:http://tool.oschina.net/apidocs/apidoc?api=cpp%2Fen%2Fcpp.htmlspa