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

目录

首先

自动转换

浮点型转化为整型

整型转换为浮点型

字符型与整型

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

强制转换


 

首先

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

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

自动转换

浮点型转化为整型

int a=2.5;

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

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

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

整型转换为浮点型

我们直接整个栗子

c语言————自动与强制数据类型转换_第1张图片

 

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

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

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

字符型与整型

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

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

c语言————自动与强制数据类型转换_第2张图片c语言————自动与强制数据类型转换_第3张图片

  •  如果不巧,会出现乱码

c语言————自动与强制数据类型转换_第4张图片c语言————自动与强制数据类型转换_第5张图片

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

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

c语言————自动与强制数据类型转换_第6张图片实数部分加小数部分一共9个6。

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

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

强制转换

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

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

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

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

就酱,拜拜~

 

 

你可能感兴趣的:(c语言)