C++ 11 学习1:类型自动推导 auto和decltype

Cocos 3.x 用了大量的C++ 11 的东西,所以作为一个C++忠实粉丝,有必要对C++ 11进行一个系统的学习。

使用C++11之前,一定要注意自己使用的编译器对C++11的支持情况,有些编译器并不是完全支持,比如我正在使用的vs2012。这里是msdn里面VS各版本对C++ 11 的支持 对 C++11 功能的支持(现代 C++)

 

1.auto

auto这个关键字C++原先就有,用来指定存储器。因为很少有人去用这个东西,所以在C++11中就把原有的auto功能给废弃掉了,而变成了现在的类型推导关键字。先说下auto的简单用法:

#include <iostream>
#include <vector>
#include <map>
using namespace std;

int main() {
    auto num = 1;  //num 是int类型
    auto c = 'A'; //c 是char类型
    auto str("test"); // str是char数组
    
    map<string, vector<int>> map;
    for(auto it = begin(map); it != end(map); ++it)  // it 为迭代器类型
    {
    }

    return 0;
}

这样使用最明显的好处就是在使用迭代器遍历STL容器的时候,不用去声明那些迭代器的类型,也不用去使用typedef就能很简洁的实现遍历了。

从效率上来说,auto不会对运行时效率产生影响,它是在编译的时候推导类型的,例如上面的代码,编译的时候,就会把num变量转换为int类型。

auto和其他变量类型有明显的区别:

1.auto声明的变量必须要初始化,否则编译器不能判断变量的类型。

2.auto不能被声明为返回值,auto不能作为形参,auto不能被修饰为模板参数

3.

2.decltype

decltype关键字和auto相互对应的,它们经常在一些场所配合使用。decltype可以在编译的时候判断出一个变量或者表达式的类型,例如:

#include <iostream>
#include <vector>
#include <map>
using namespace std;

void func(auto can) {
    int a;
}

int main() {
    auto num = 1;  //num 是int类型
    decltype(num) num2 = num; //num2 也是int类型

    return 0;
}

这里decltype拿到了num的类型,然后用这个类型定义了num2做了num的一份copy。auto和decltype还有一种经典的使用场合,看下面例子:

template <typename T1, typename T2>  
auto compose(T1 t1, T2 t2) -> decltype(t1 + t2)  
{  
   return t1+t2;  
}

这里是用一个模板来计算两个变量的加法,如果两个类型T1和T2不一样的话,t1+t2的类型将由编译器来决定,这样使用decltype就可以拿到返回的类型。但是如果把decltype(t1 + t2)放到函数命名的前面作为返回值的话,按照编译器的解析顺序,当解析到返回值decltype(t1 + t2)的时候t1和t2还没有被定义,所以要重新声明t1和t2的类型,这样就会变的很复杂很难读懂。

于是C++11就改变了语法规则,把decltype(t1 + t2)放到函数的后方,并用auto作为返回值来告诉编译器,真正的返回值在函数声明之后。简单的说auto可以作为返回值占位符来使返回值后置。

 

posted @ 2015-07-28 16:08  andyidea  阅读(3961)  评论(0编辑  收藏  举报