关于C++的数据类型......

intk=7;floatf;那么表达式k>0?k:f的数据类型为什么是double啊?你说如果右边量的数据类型长度左边长时,丢失的部分按四舍五入向前舍入,那如下定义int... int k=7;
float f;
那么表达式k>0?k:f的数据类型为什么是double啊?
你说如果右边量的数据类型长度左边长时,丢失的部分按四舍五入向前舍入,那如下定义int a=2.8*6;右面是16.8,输出结果却是16,怎么回事啊?
展开
 我来答
柯田eg
2007-03-27 · 超过22用户采纳过TA的回答
知道答主
回答量:59
采纳率:0%
帮助的人:0
展开全部
变量的数据类型是可以转换的。转换的方法有两种, 一种是自动转换,一种是强制转换。

自动转换
自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3.所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
5.在赋值运算中,赋值号两边量的数据类型不同时, 赋值号右边量的类型将转换为左边量的类型。 如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度, 丢失的部分按四舍五入向前舍入。

当参加算术或比较运算的两个操作数类型不统一时,将简单类型向复杂类型转换,
char(short) -> int(long) -> float -> double
而你的问题就是一个在不同变量在参与同一运算时的自动转换问题.
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
找油人
2007-03-27 · 超过20用户采纳过TA的回答
知道答主
回答量:79
采纳率:0%
帮助的人:0
展开全部
C++语言中,遇到int、float、double类型的混合运算,运算规则是把所有的数据都先转化成double,然后再进行计算,这里是int与float混合运算,按照运算规则,把k与f都转化成double进行计算,最后结果当然是double了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式