lambda的参数可以使用auto
int ret = [](int input){return input* input;}{10}; //C++11
auto func = [](auto input){return input*input;};
cout<<func(11)<<' '<<func(3.14)<<endl;
constexpr支持if switch和循环...
constexpr函数是一种编译期和运行期都能被调用执行的函数。用一套代码来实现。如果编译期常量参数调用constexpr函数,就能够在编译期得到运算结果;使用运行期变量参数调用constexpr就在运行期得到结果
C++11 中,编译器的数值计算可以通过使用constexpr声明并定义编译期函数来进行,但constexpr函数所受到的限制较多,比如函数体通常只有一句return语句, 函数体内既不能声明变量也不能使用for语句之类的常规控制流语句,比如factor函数,在编译期计算阶乘任然需要利用递归技巧
在C++14中,解除了对constexpr函数的大部分限制,在constexpr函数体内我们既可以声明变量,也可以使用除goto和try之外的大部分控制流语句,如factor2函数所示,在编译期计算阶乘只需利用for语句进行常规计算即可
//C++11
constexpr int factor(int n)
{
return n == 0 ? 1 : n * (n - 1);
}
//C++14
constexpr int factor2(int n)
{
int res = 1;
for (int i = 1; i <= n; ++i)
res *= i;
return res;
}
类型推导:11仅支持lambda函数返回类型推导 ,14支持所有函数返回类型推导 decltype(auto)
decltype(auto)是C++14新增的类型指示符,可以用来声明变量以及指示函数返回类型
//11
template<typename _Tx,typename _Ty>
auto Add(_Tx x, _Ty y)->decltype(x + y)
{
return x + y;
}
//14
template<typename _Tx, typename _Ty>
decltype(auto)Add(_Tx x, _Ty y)
{
return x + y;
}
0b或0B二进制常量
int a = 0b10101100;
int b = 0B10101010;