注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

还东国的博客

行之苟有恒,久久自芬芳

 
 
 

日志

 
 

(转载)c++11新特性--decltype -----c++0x新特性  

2013-04-17 16:58:34|  分类: C++(VC)编程 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

c++11新特性--decltype

分类: 外文整理 2012-03-03 16:15 902人阅读 评论(0) 收藏 举报

c++classstructfunctionc返回值 decltype(表达式)

http://blog.csdn.net/yshe_xun/article/details/7315636

 

[返回值的类型是表达式参数的类型]

 

这个可也用来决定表达式的类型,就像Bjarne暗示的一样,如果我们需要去初始化某种类型的变量,auto是最简单的选择,但是如果我们所需的类型不是一个变量,例如返回值这时我们可也试一下decltype

现在我们回看一些例子我们先前做过的,

 

template <class U, class V> 

void Somefunction(U u, V v) 

    result = u*v;//now what type would be the result???  

    decltype(u*v) result = u*v;//Hmm .... we got what we want  

 

template <class U, class V>

void Somefunction(U u, V v)

{

    result = u*v;//now what type would be the result???

    decltype(u*v) result = u*v;//Hmm .... we got what we want

}

在下面的一个段落我将会让你熟悉这个观念用 auto decltype 来声明模板函数的返回值,其类型依靠模板参数。

1. 如果这个表达式是个函数,decltype 给出的类型为函数返回值的类型。

int add(int i, int j){ return i+j; } 

decltype(add(5,6)) var = 5;//Here the type of var is return of add() -> which is int 

 

    int add(int i, int j){ return i+j; }

    decltype(add(5,6)) var = 5;//Here the type of var is return of add() -> which is int

 

2.如果表达式是一个左值类型,那么 decltype 给出的类型为表达式左值引用类型。

 

 

struct M { double x; }; 

 

double pi = 3.14; 

const M* m = new M(); 

decltype( (m->x) ) piRef = pi; 

 

    // Note: Due to the inner bracets the inner statement is evaluated as expression,  

    // rather than member 'x' and as type of x is double and as this is lvale  

    // the return of declspec is double& and as 'm' is a const pointer   

    // the return is actually const double&.  

    // So the type of piRef is const double& 

 

struct M { double x; };

 

double pi = 3.14;

const M* m = new M();

decltype( (m->x) ) piRef = pi;

 

    // Note: Due to the inner bracets the inner statement is evaluated as expression,

    // rather than member 'x' and as type of x is double and as this is lvale

    // the return of declspec is double& and as 'm' is a const pointer

    // the return is actually const double&.

    // So the type of piRef is const double&

3.非常重要的标记一下,decltype 不会执行表达式而auto会,他仅仅推论一下表达式的类型。

int foo(){} 

decltype( foo() ) x; // x is an int and note that   

                     // foo() is not actually called at runtime 

 

    int foo(){}

    decltype( foo() ) x; // x is an int and note that

                         // foo() is not actually called at runtime

跟踪返回类型:

这对 C++ 开发者来说是一个全新的特性,直到现在函数的返回类型必须放在函数名的前面。到了 C++11,我们也可以将函数返回值的类型放在函数声明后,当然仅需要用 auto 替代返回类型。现在我们想知道怎么做,让我们来寻找答案:

template<class U, class V> 

??? Multiply(U u, V v)    // how to specifiy the type of the return value  

{  

   return u*v; 

 

template<class U, class V>

??? Multiply(U u, V v)    // how to specifiy the type of the return value

{

   return u*v;

}

我们明显的不能像这样:

 

 

template<class U, class V> 

decltype(u*v) Multiply(U u, V v)    // Because u & v are not defined before Multiply.  

                     //  What to do...what to do !!!  

{  

   return u*v; 

 

template<class U, class V>

decltype(u*v) Multiply(U u, V v)    // Because u & v are not defined before Multiply.

                     //  What to do...what to do !!!

{

   return u*v;

}

这种情况我们可也使用 auto 然后当我们使用 decltype(u*v) 作为返回值这个类型便知晓了.

这是不是很酷?

template<class U, class V> 

auto Multiply(U u, V v) -> decltype(u*v)    // Note -> after the function bracet.  

{  

   return u*v; 

}  

  评论这张
 
阅读(1001)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017