auto让编译器通过出初始值来推算变量的类型,显然,auto定义的变量必须有初始值:
//由val1和val2相加的结果可以推断出item的类型 auto item = val1 + val2;//item初始化为val1和val2相加的结果
使用auto也能在一条语句中声明多个变量,因为一条语句中只能有一种基本数据类型,所以该语句中所有变量的初始基本数据类型都必须一样:
auto i = 0, *p = &i;//正确:i是整数、p是整型指针 auto sz = 0, pi = 3.14;//错误:sz和pi类型不一样
复合类型、常量和auto
编译器推断出来的auto类型有时候和初始值的类型不完全一样,编译器会适当地改变结果类型使其更符合初始化规则。
使用引用其实是使用引用的对象,特别是当引用被用作初始值时,真正参与初始化的其实是引用对象的值。
此时编译器以引用对象的类型作为auto的类型:
int i = 0, &r = i; auto a = r;//a是一个整数
auto一般会忽略顶层const,同时底层const则会保留下来,比如当初始值是一个指向常量的指针时:
const int ci = i, &cr = ci; auto b = ci;//b是一个整数(ci的顶层const特性被忽略掉了) auto c = cr;//c是一个整数(cr是ci的别名,ci本身是一个顶层const) auto d = &i;//d是一个整型指针(整数的地址就是指向整数的指针) auto e = &ci;//e是一个指向整数常量的指针(对常量对象的取地址是一种底层const)
如果希望推断出的auto类型是一个顶层const,需要明确指出:
const auto f = ci;//ci的推演类型是int,f是const int
将引用的类型设为auto,此时原来的初始化规则仍然适合:
auto &g = ci;//g是一个整型常量引用,绑定到ci auto &h = 42;//错误:不能为非常量引用绑定字面值 const auto &j = 42;//正确:可以为常量引用绑定字面值
- 设置一个类型为auto的引用时,初始值中的顶层常量属性仍然保留。
- 给初始值绑定一个引用时,则此时的常量就不是顶层常量。
auto k = ci, &l = i;//k时整数,l是整型引用 auto &m = ci, *p = &ci;//m是对整型常量的引用,p是指向整型常量的指针 auto &n = i, *p2 = &ci;//错误:i的类型是int而&ci的类型是const int