龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > C/C++开发 >

C++ 11中的auto和decltype

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
C++ 11中引入的auto主要有两种用途:自动类型推断和返回值占位。auto在C++ 98中的标识临时变量的语义,由于使用极少且多余,在C++ 11中已被删除。 auto自动类型推断,用于从初始化表达式

C++ 11中引入的auto主要有两种用途:自动类型推断和返回值占位。auto在C++ 98中的标识临时变量的语义,由于使用极少且多余,在C++ 11中已被删除。

auto自动类型推断,用于从初始化表达式中推断出变量的数据类型。通过auto的自动类型推断,可以大大简化我们的编程工作。下面是一些使用auto的例子。

  1. auto a; // 错误,没有初始化表达式,无法推断出a的类型  
  2. auto int a = 10 // 错误,auto临时变量的语义在C++ 11中已不存在  
  3. auto a = 10  
  4. auto c = 'A' 
  5. auto s("hello");  
  6. vector<int> vctTemp;  
  7. auto it = vctTemp.begin();  
  8. auto ptr = [](){ cout << "hello world" << endl; }; 

另外,在使用模板技术时,如果某个变量的类型依赖于模板参数,不使用auto将很难确定变量的类型(使用auto后,将由编译器自动进行确定)。下面是一个具体的例子。

  1. template <class T, class U>  
  2. void Multiply(T t, U u)  
  3. {  
  4. auto v = t*u;  

auto返回值占位,主要与decltype配合使用,用于返回值类型后置时的占位。

  1. template <class T, class U>  
  2. auto Multiply(T t, U u)->decltype(t*u)  
  3. {  
  4. typedef decltype(t*u) NewType;  
  5. NewType *pResult = new NewType(t*u);  
  6. return *pResult;  

至于为什么需要将返回值类型后置,这里简单说明一下。如果没有后置,则函数声明为decltype(t*u) Multiply(T t, U u),但此时模板参数t和u还未声明,编译无法通

过。另外,如果非要使用返回值类型前置的形式,也可以将函数声明为decltype((*(T *)0)*(*(U *)0)) Multiply(T t, U u),但这种形式比较晦涩难懂,因此不推荐采用。

原文地址:http://www.cnblogs.com/hujian/archive/2012/02/15/2352050.html

【编辑推荐】


精彩图集

赞助商链接