首先
数据类型转换,即把一个变量从某种数据类型转换为另一种数据类型。(常量不可以)
转换方式一般有两种:自动转换和强制转换,我们在下面具体讲解。
自动转换
浮点型转化为整型
int a=2.5;
遇到这种情况系统会自动把2.5转换为整型,这就叫做自动转换。
猜猜转换方式是四舍五入还是直接舍去?
答案是:直接舍去小数点后数字。
整型转换为浮点型
我们直接整个栗子
把整型赋值给浮点型,如图所示系统自动加上小数点。
但是有没有发现输出的两个数字和我赋值的不一样,有两个数字乱了。
原因是float可以保存7个准确数字(整数部分和小数部分一共7位),其余部分则会丢失。double可以准确保存16位数字,如图剩下两位丢失。
字符型与整型
由于字符在系统内由ASCII码形式保存,所以整型与字符型可以说是穿一条裤子的好基友。
- 如果碰巧了,字符对应其ASCII码值,系统会很丝滑的进行自动转换🌰
- 如果不巧,会出现乱码
单精度浮点型和双精度浮点型
如果double型赋值给float型,那么按照四舍五入减少有效位数。
实数部分加小数部分一共9个6。
( float可以准确保存7位数字,double可以准确保存16位。)
如图,第8、9个6被舍去,进行四舍五入,所以第7个6就进一变成7。
强制转换
比如🌰(其中变量名称无所谓)
1. float a=3.14; 2. b=(int)a;
变量a本身是浮点型,当前面加上(int)就会被强制转换为整型。