C++中的数据类型的自动转换?

哪些和哪些之间是可以自动转换的?就是说在函数调用时,所传参数与声明的参数类型不一致时做的转换,比如float和char,double和char,这些都可以吗?还有哪些?... 哪些和哪些之间是可以自动转换的?就是说在函数调用时,所传参数与声明的参数类型不一致时做的转换,比如float和char,double和char,这些都可以吗?还有哪些? 展开
 我来答
尚彤错雅青
2019-09-13 · TA获得超过4134个赞
知道大有可为答主
回答量:3182
采纳率:34%
帮助的人:415万
展开全部
变量的数据类型是可以转换的。转换的方法有两种,
一种是自动转换,一种是强制转换。
自动转换
自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3.所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
5.在赋值运算中,赋值号两边量的数据类型不同时,
赋值号右边量的类型将转换为左边量的类型。
如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,
丢失的部分按四舍五入向前舍入。
当参加算术或比较运算的两个操作数类型不统一时,将简单类型向复杂类型转换,
char(short)
->
int(long)
->
float
->
double
下面程序段表示了类型自动转换的规则。
void
main(){
float
PI=3.14159;
int
s,r=5;
s=r*r*PI;
printf("s=%d\n",s);
}
PI<--3.14159
s<--0,r<--5
s<--r*r*PI
显示程序运行结果:
float
PI=3.14159;
int
s,r=5;
s=r*r*PI;
本例程序中,PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式