关于类型转换和整数提升的问题

Ashily_1020 2014-03-17 09:49:23
在C++ primer上面有:
3.14159 + 'a' ; //promote 'a ' to int, then convert to long double
cval + fval ; //cval promoted to int, that int converted to float
cavl + lval ; //cavl converted to long
对这三个例子我不是很理解,宽度比int小的,在算数运算时,自动提升为int型,但是在和宽度比int型大的数做算数运算时,也是先提升再转换,再运算吗??中间有几个临时变量?

那cavl + lval ; //cavl converted to long 为什么不先整数提升呢?

...全文
116 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Ashily_1020 2014-03-17
  • 打赏
  • 举报
回复
引用 3 楼 turingo 的回复:
不会,编译器在帮忙处理的。 [quote=引用 2 楼 cocodada 的回复:] [quote=引用 1 楼 turingo 的回复:] 有浮点数的时候,才需要多次提升。 [quote=引用 楼主 cocodada 的回复:] 在C++ primer上面有: 3.14159 + 'a' ; //promote 'a ' to int, then convert to long double cval + fval ; //cval promoted to int, that int converted to float cavl + lval ; //cavl converted to long 对这三个例子我不是很理解,宽度比int小的,在算数运算时,自动提升为int型,但是在和宽度比int型大的数做算数运算时,也是先提升再转换,再运算吗??中间有几个临时变量? 那cavl + lval ; //cavl converted to long 为什么不先整数提升呢?
[/quote] 多此提升的过程中,会产生多个临时变量么?[/quote][/quote] 再问问哈,cavl + lval ; 是直接从char 转换成long?中间没有类型转换?类型转换中间有临时变量么?这个感觉挺糊的。。。
图灵狗 2014-03-17
  • 打赏
  • 举报
回复
不会,编译器在帮忙处理的。
引用 2 楼 cocodada 的回复:
[quote=引用 1 楼 turingo 的回复:] 有浮点数的时候,才需要多次提升。 [quote=引用 楼主 cocodada 的回复:] 在C++ primer上面有: 3.14159 + 'a' ; //promote 'a ' to int, then convert to long double cval + fval ; //cval promoted to int, that int converted to float cavl + lval ; //cavl converted to long 对这三个例子我不是很理解,宽度比int小的,在算数运算时,自动提升为int型,但是在和宽度比int型大的数做算数运算时,也是先提升再转换,再运算吗??中间有几个临时变量? 那cavl + lval ; //cavl converted to long 为什么不先整数提升呢?
[/quote] 多此提升的过程中,会产生多个临时变量么?[/quote]
Ashily_1020 2014-03-17
  • 打赏
  • 举报
回复
引用 1 楼 turingo 的回复:
有浮点数的时候,才需要多次提升。 [quote=引用 楼主 cocodada 的回复:] 在C++ primer上面有: 3.14159 + 'a' ; //promote 'a ' to int, then convert to long double cval + fval ; //cval promoted to int, that int converted to float cavl + lval ; //cavl converted to long 对这三个例子我不是很理解,宽度比int小的,在算数运算时,自动提升为int型,但是在和宽度比int型大的数做算数运算时,也是先提升再转换,再运算吗??中间有几个临时变量? 那cavl + lval ; //cavl converted to long 为什么不先整数提升呢?
[/quote] 多此提升的过程中,会产生多个临时变量么?
图灵狗 2014-03-17
  • 打赏
  • 举报
回复
有浮点数的时候,才需要多次提升。
引用 楼主 cocodada 的回复:
在C++ primer上面有: 3.14159 + 'a' ; //promote 'a ' to int, then convert to long double cval + fval ; //cval promoted to int, that int converted to float cavl + lval ; //cavl converted to long 对这三个例子我不是很理解,宽度比int小的,在算数运算时,自动提升为int型,但是在和宽度比int型大的数做算数运算时,也是先提升再转换,再运算吗??中间有几个临时变量? 那cavl + lval ; //cavl converted to long 为什么不先整数提升呢?

65,209

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧