导言
此次笔记分为三部分介绍
- typedef 基本使用与cpp11新特性
- 自动推演数据类型
- decltype使用(主要集中介绍)
typedef
typedef使用方法很简单,就是为一个数据类型取一个别名
格式为:
typedef 数据类型 别名
typedef long long ll; // 为long long型取了一个别名ll
ll li = 123456; // 直接使用别名作为数据类型填充进去
除此之外还有cpp11新增的特性,即使用using来为数据类型取别名,请见以下代码
using DB = double; // 该代码typedef效果完全一致,为double去别名DB
DB dou = 3.22;
auto 自动推演数据类型(C++11特性)
当我们无法精确判断一个数据类型的时候可以使用其代替之
以下我们使用迭代器(以后的笔记会介绍,这里仅做演示使用)来展示auto的神奇之处
#include<vector> // 这里使用向量来演示,需要导入头文件vector
#include<iterator> // 使用迭代器也需要导入头文件
vector<int> vec1{1,2,3,4}; // 新声明一个向量
auto v1 = vec1.begin(); // 获取该向量的迭代器
vector<int>::iterator v2 = vec1.begin(); // 和上一条语句效果完全一致,只不过不使用auto
// 一个更简单的示例,使用auto自动推演数据类型为int(根据我们传入的初始值的类型来判定)
auto nums = 123; // auto推断为int
PS:vector的专用迭代器数据类型为vector::iterator
可见,使用自动推演数据类型的方法将极大地提高我们的效率
上面的代码就展示了用auto推演出数据类型vector::iterator,省去了手写的麻烦
decltype使用(C++11特性)
decltype主要作用就是获取指定参数的数据类型
下面是一段示例代码帮助大家更好理解
// 用返回值为Int的方法test来存放我们的代码
int test(){
// decltype对一个方法使用则返回该方法的返回值类型,下方代码返回int
// 所以此刻就声明了一个变量nums,且他的数据类型为int
decltype(test()) nums = 123;
// decltype还可以识别一个变量,甚至是一个表达式所表达的最终数据类型
// 因变量n为int类型,所以decltype(n)返回值为int
// 因为遵循低精度与高精度运算是自动转换高精度原则,故n+1.0自动转换为double类型
// 所以decltype(n+1.0)返回值为double
int n = 0;
decltype(n) n1 = 100;
decltype(n+1.0) = 4.33;
// decltype还可以识别一个引用类型
int m1=0;
int &m2=m1; // 引用类型必须初始化,如下一行decltype一样也需要初始化,否则报错
decltype(m2) m3 = m1; // decltype(m2)返回一int&也就是int的引用类型
// 特别的,当decltype内传入放一基本数据类型且再用一个圆括号把他括起来时,返回该数据类型的引用
// 如m1是int类型,但他外面又包裹一层圆括号,所以decltype((m1))返回int&类型
decltype((m1)) m4 = m1;
}
具体的代码细节与语法都详尽的写入了以上的代码块中,后续细节待笔者详细参考特定资料后再进行填充