C++11类型别名和typedef有什么区别
这篇文章主要讲解了“C++11类型别名和typedef有什么区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++11类型别名和typedef有什么区别”吧!
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站设计、红寺堡网络推广、微信平台小程序开发、红寺堡网络营销、红寺堡企业策划、红寺堡品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供红寺堡建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
为什么需要别名
下面的说明只是一个例子,实际的使用场景一定不止这些。
假设有一个二维图形计算的程序,定义了一个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
vector
while(it != v.end()){
cout << (*it).x << "," << (*it).y << endl;
it++;
}
如果类似代码多次出现,每次输入相同的内容,有些人就会觉得麻烦。这时可以为vector
using PointVector = vector
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
typedef void(*PtoF)(int); //等价于using PtoF=void(*)(int);
C++11的别名定义方式似乎更容易理解一些。除此以外区别似乎不大,就看你怎么选了。
感谢各位的阅读,以上就是“C++11类型别名和typedef有什么区别”的内容了,经过本文的学习后,相信大家对C++11类型别名和typedef有什么区别这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
文章标题:C++11类型别名和typedef有什么区别
网页地址:http://azwzsj.com/article/jgdedd.html