设有定义:int a=7;float x=2.5,y=4.7;则表达式x+a%3*(int)(x+y)%2/4的值是(2.5)//这串代码应该怎么读取呢
若有定义:char a;int b;float c;double d;则表达式a*b+d-c值的类型为(double)//为什么答案是double,怎么理解
我有两个小问题想问一下
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- bekote 2022-03-18 17:35关注
首先数据类型隐式转换规则如下
{char, uchar, short, ushort}->int-> uint->long->ulong->float->double
隐式转换从低精度到高精度,例如 char类型+int类型,得到的结果是int类型的
按照运算优先级本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 gg加速器加速游戏时,提示不是x86架构
- ¥15 python按要求编写程序
- ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
- ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
- ¥15 opencv图像处理,需要四个处理结果图
- ¥15 无线移动边缘计算系统中的系统模型
- ¥15 深度学习中的画图问题
- ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条
- ¥15 Python报错怎么解决
- ¥15 simulink如何调用DLL文件