c语言————自动与强制数据类型转换

发布于:2023-01-04 ⋅ 阅读:(685) ⋅ 点赞:(0)

目录

首先

自动转换

浮点型转化为整型

整型转换为浮点型

字符型与整型

单精度浮点型和双精度浮点型

强制转换


 

首先

数据类型转换,即把一个变量从某种数据类型转换为另一种数据类型。(常量不可以)

转换方式一般有两种:自动转换和强制转换,我们在下面具体讲解。

自动转换

浮点型转化为整型

int a=2.5;

遇到这种情况系统会自动把2.5转换为整型,这就叫做自动转换。

猜猜转换方式是四舍五入还是直接舍去?

答案是:直接舍去小数点后数字。

整型转换为浮点型

我们直接整个栗子

3732000341c142cb85b067db0338fe67.png

 

把整型赋值给浮点型,如图所示系统自动加上小数点。

但是有没有发现输出的两个数字和我赋值的不一样,有两个数字乱了。

🔎原因是float可以保存7个准确数字(整数部分和小数部分一共7位),其余部分则会丢失。double可以准确保存16位数字,如图剩下两位丢失。

字符型与整型

由于字符在系统内由ASCII码形式保存,所以整型与字符型可以说是穿一条裤子的好基友。

  • 如果碰巧了,字符对应其ASCII码值,系统会很丝滑的进行自动转换🌰

5d9957b706a34dc78991ba3f6fed6fac.pngeffcf3da16fc48c1935917787fd4686e.png

  •  如果不巧,会出现乱码

fba76fb35ba04bf5988fbbf46569a086.png6adc02028e054a058fd1cb5734caf8df.png

单精度浮点型和双精度浮点型

如果double型赋值给float型,那么按照四舍五入减少有效位数。

8f5618b327bb44e6aa0ad08774544e84.png实数部分加小数部分一共9个6。

( float可以准确保存7位数字,double可以准确保存16位。)

如图,第8、9个6被舍去,进行四舍五入,所以第7个6就进一变成7。

强制转换

比如🌰(其中变量名称无所谓)

float a=3.14;
b=(int)a;

变量a本身是浮点型,当前面加上(int)就会被强制转换为整型。

(学识尚浅,强制类型转换目前只掌握这种)

就酱,拜拜~

 

 

本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到