C++11类型别名和typedef有什么区别
这篇文章主要讲解了“C++11类型别名和typedef有什么区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++11类型别名和typedef有什么区别”吧!
为什么需要别名
下面的说明只是一个例子,实际的使用场景一定不止这些。
假设有一个二维图形计算的程序,定义了一个point结构体。
struct point
{
int x;
int y;
};
在有些系统中,int类型的精度,范围都足够,在其他的系统中可能就不能满足需求,可能需要扩大字长,或者需要提高精度等等。
方法有多种,其中之一就是定义别名。在C++11中定义别名的方法如下:
using dtype = int;
它的含义是为int指定一个别名,dtype。指定别名以后,point结构体变成下面这样:
struct point
{
dtype x;
dtype y;
};
这样一来,只要改变dtype所对应的数据类型,所有使用point的代码都会适应这种变化。
下面说明另一种场景。继续假设这个程序中也会用到vector:
vector<point> v = {{1, 2}, {3, 4}};
vector<point>::iterator it = v.begin();
while(it != v.end()){
cout << (*it).x << "," << (*it).y << endl;
it++;
}
如果类似代码多次出现,每次输入相同的内容,有些人就会觉得麻烦。这时可以为vector<point>定义一个别名:
using PointVector = vector<point>; //定义别名
PointVector va = {{1, 2}, {3, 4}};
PointVector::iterator ita = va.begin();
while(ita != va.end()){
cout << (*ita).x << "," << (*ita).y << endl;
ita++;
}
定义别名,提供了另一种看程序的方式。
类型别名和typedef有什么区别?
typedef也能提相同的功能,但是形式略有不同。
typedef int dtype; //等价于using dtype = int;
typedef vector<point> PointVector; //等价于using Point
typedef void(*PtoF)(int); //等价于using PtoF=void(*)(int);
C++11的别名定义方式似乎更容易理解一些。除此以外区别似乎不大,就看你怎么选了。
感谢各位的阅读,以上就是“C++11类型别名和typedef有什么区别”的内容了,经过本文的学习后,相信大家对C++11类型别名和typedef有什么区别这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341