C11 新特性

auto

在C++11之前,auto关键字用来指定存储期。在新标准中,它的功能变为类型推断。auto现在成了一个类型的占位符,通知编译器去根据初始化代码推断所声明变量的真实类型。各种作用域内声明变量都可以用到它。例如,名空间中,程序块中,或是for循环的初始化语句中。

 

 

auto i = 42; // i is an int

 

auto l = 42LL; // l is an long long

 

auto p = new foo(); // p is a foo*

使用auto通常意味着更短的代码(除非你所用类型是int,它会比auto少一个字母)。试想一下当你遍历STL容器时需要声明的那些迭代器(iterator)。现在不需要去声明那些typedef就可以得到简洁的代码了。

 

 

 

 

 

std::map<std::string, std::vector<int>> map;

 

for(auto it = begin(map); it != end(map); ++it)

 

{

 

}

需要注意的是,auto不能用来声明函数的返回值。但如果函数有一个尾随的返回类型时,auto是可以出现在函数声明中返回值位置。这种情况下,auto并不是告诉编译器去推断返回类型,而是指引编译器去函数的末端寻找返回值类型。在下面这个例子中,函数的返回值类型就是operator+操作符作用在T1、T2类型变量上的返回值类型。

 

 

 

 

 

template <typename T1, typename T2>

 

auto compose(T1 t1, T2 t2) -> decltype(t1 + t2)

 

{

 

return t1+t2;

 

}

 

auto v = compose(2, 3.14); // v's type is double

 

nullptr

以前都是用0来表示空指针的,但由于0可以被隐式类型转换为整形,这就会存在一些问题。关键字nullptr是std::nullptr_t类型的值,用来指代空指针。nullptr和任何指针类型以及类成员指针类型的空值之间可以发生隐式类型转换,同样也可以隐式转换为bool型(取值为false)。但是不存在到整形的隐式类型转换。

 

std::map<std::string, std::vector<int>> map;

 

std::vector<int> v;

 

v.push_back(1);

 

v.push_back(2);

 

v.push_back(3);

 

map["one"] = v;

 

for(const auto& kvp : map)

 

{

 

std::cout << kvp.first << std::endl;

 

for(auto v : kvp.second)

 

{

 

std::cout << v << std::endl;

 

}

 

}

 

int arr[] = {1,2,3,4,5};

 

for(int& e : arr)

 

{

 

e = e*e;

 

}

static_assert和 type traits

static_assert提供一个编译时的断言检查。如果断言为真,什么也不会发生。如果断言为假,编译器会打印一个特殊的错误信息。

 

template <typename T, size_t Size>

 

class Vector

 

{

 

static_assert(Size < 3, "Size is too small");

 

T _points[Size];

 

};

 

int main()

 

{

 

Vector<int, 16> a1;

 

Vector<double, 2> a2;

 

return 0;

 

}

 

error C2338: Size is too small

 

see reference to class template instantiation 'Vector<T,Size>' being compiled

 

with

 

[

 

T=double,

 

Size=2

 

]

 

Range-based for loops (基于范围的for循环)

为了在遍历容器时支持”foreach”用法,C++11扩展了for语句的语法。用这个新的写法,可以遍历C类型的数组、初始化列表以及任何重载了非成员的begin()和end()函数的类型。

如果你只是想对集合或数组的每个元素做一些操作,而不关心下标、迭代器位置或者元素个数,那么这种foreach的for循环将会非常有用。

 

std::map<std::string, std::vector<int>> map;

 

std::vector<int> v;

 

v.push_back(1);

 

v.push_back(2);

 

v.push_back(3);

 

map["one"] = v;

 

for(const auto& kvp : map)

 

{

 

std::cout << kvp.first << std::endl;

 

for(auto v : kvp.second)

 

{

 

std::cout << v << std::endl;

 

}

 

}

 

int arr[] = {1,2,3,4,5};

 

for(int& e : arr)

 

{

 

e = e*e;

 

}

这只是其中的一些更改,和变动,想知道更多,访问下面网址http://blog.jobbole.com/44015/

 

你可能感兴趣的:(C11)