1 类型别名是一个名字,它是某种类型的同义词。
2 有两种方法可用于定义类型别名,typedef 和 using
typedef double wages; // wages是double的同义词
using SI = Sales_item; // SI是Sales_item的同义词
3 auto让编译器通过初始值来推算变量的类型。显然,auto定义的变量必须有初始值。
auto item = val1 + val2;
4 当引用被用作初始值时,真正参与初始化的其实是引用对象的值,此时编译器以引用对象的类型作为auto的类型:
int i = 0; &r = i;
auto a = r; // a是int类型
5 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)
6 decltype 它的作用是选择并返回操作数的数据类型。在此过程中,编译器分析表达式并得到它的类型,却不实际计算表达式的值。
decltype(f()) sum = x; // sum的类型就是函数f的返回类型
decltype(a) b = c; // a是什么类型,b就是类型,一模一样
7 引用从来都作为其所指对象的同义词出现,只有用在decltype处是个例外。
2 有两种方法可用于定义类型别名,typedef 和 using
typedef double wages; // wages是double的同义词
using SI = Sales_item; // SI是Sales_item的同义词
3 auto让编译器通过初始值来推算变量的类型。显然,auto定义的变量必须有初始值。
auto item = val1 + val2;
4 当引用被用作初始值时,真正参与初始化的其实是引用对象的值,此时编译器以引用对象的类型作为auto的类型:
int i = 0; &r = i;
auto a = r; // a是int类型
5 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)
6 decltype 它的作用是选择并返回操作数的数据类型。在此过程中,编译器分析表达式并得到它的类型,却不实际计算表达式的值。
decltype(f()) sum = x; // sum的类型就是函数f的返回类型
decltype(a) b = c; // a是什么类型,b就是类型,一模一样
7 引用从来都作为其所指对象的同义词出现,只有用在decltype处是个例外。