zoukankan      html  css  js  c++  java
  • C++11之auto和decltype

    • auto自动类型推断,用于从初始表达式中推断出变量的类型。
    1. auto a;// 错误,没有初始化表达式,无法推断出a的类型
    2. autoint 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返回值占位,主要与decltype配合使用,用于返回值类型后置时的占位。
    1. template<class T,class U>
    2. autoMultiply(T t, U u)->decltype(t*u)
    3. {
    4. typedefdecltype(t*u)NewType;
    5. NewType*pResult =newNewType(t*u);
    6. return*pResult;
    7. }
    decltype相关用法说明
    类似于sizeof操作符,decltype也不需对其操作数求值(而auto会执行表达式)。粗略来说,decltype(e)返回类型前,进行了如下推导:
    1. 若表达式e指向一个局部变量、命名空间作用域变量、静态成员变量或函数参数,那么返回类型即为该变量(或参数)的“声明类型”;
    2. 若e是一个左值(lvalue,即“可寻址值”),则decltype(e)将返回T&,其中T为e的类型;
    3. 若e是一个x值(xvalue),则返回值为T&&;
    4. 若e是一个纯右值(prvalue),则返回值为T。
       

    1、表达式根据其值的类型可分为以下三类:

    • lvalue:左值,即传统意义上的左值。
    • xvalue(expiring value):x值(中间值?),指通过“右值引用”产生的对象。
                                       这里x可以理解为即将消失(expiring),也可理解为中间(横跨左值和右值)。
    • prvalue(pure rvalue):纯右值,即传统意义上的右值。
    2、两种复合类型:
    • glvalue(general lvalue):泛左值,由左值和x值构成。泛左值具有动态的类型和对象属性。
    • rvalue:右值,由x值和纯右值构成。右值具有潜在的可移动性。
    3、关于右值引用:
    • 具名右值引用被视为左值。
    • 无名右值引用被视为x值。
    • 对函数的右值引用无论具名与否都将被视为左值。
    1. decltype(fun()) sum = x;//sum的类型就是函数fun的返回值类型
    2. constint ci =0,&cj = ci;
    3. decltype(ci) x =0;//x的类型是const int型
    4. decltype(cj) y = x;//y的类型是const int&,y绑定到变量x
    5. decltype(cj) z;//错误,引用类型必须被初始化
    6. int i =42,*p =&i,&r = i;
    7. decltype(r +0) b;//r+0的结果是int型
    8. //通过解引用可以给指针指向的对象赋值,说明解引用操作返回的是引用类型的
    9. decltype(*p) c;//错误,c是int&,必须被初始化
    10. //decltype结果类型与表达式形式密切相关
    11. decltype((i)) d;//错误,d是int&类型,必须初始化
    12. decltype(i) e;//正确,e是一个int类型
     





  • 相关阅读:
    IbatisNet 快速开发使用 之一
    C#开发和调用Web Service
    如何构建银行数据仓库
    SQLSREVER如何创建和使用动态游标
    一个sql语句,包含有几乎所有标准查询语法
    深入研究SQL结构化查询语言中的LIKE语句
    数据库正规化和设计技巧
    黑客攻破SQL服务器系统的十种方法
    实用的存储过程
    数据库人员手边系列:SQL Server常见连接错误
  • 原文地址:https://www.cnblogs.com/fengkang1008/p/4652221.html
Copyright © 2011-2022 走看看