温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++11类型别名和typedef有什么区别

发布时间:2021-11-26 14:33:14 来源:亿速云 阅读:166 作者:iii 栏目:大数据

这篇文章主要讲解了“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有什么区别这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI