黑马程序员-c语言-类型强制转换

时间:2022-06-12 10:50:44

强制转换的条件:

1、当所声明的类型不能满足所符值的变量时,需要转换声明的类型,以便能够存储变量。

例如:short存储的最大值为32767,但是所要符值大于32767时,short类型不符合,需要转换short类型。short MarSold = 61600;时就是错的。

2、丢失精度,当除以一个1.0和除以1是不同的。可能造成值的差别。整型除以整型只能得到整型,符值前先进行四舍五入后再符值。a=int/int,就算a是float但是得到是四舍五入后的值。可以将int转成float就可以得到精度计算了。

所以必须掌握强制转换

要把变量从一种类型转换为另一种类型,应该把目标类型放在变量前面的括号中,这种显示的转换称为强制类型转换。

double sum = 0.0;

int x = 1; int y = 2;

sum = (double)(x + y) / 2 - (x + y) / (double)(x * x + y * y);

隐式类型转换:在存在不同类型的值操作时编译的时候,编译器在处理设计,会按照一定规则吧其中一个操作数的类型转换为另一个操作数的类型

1、规则总体就是按照精度高的将精度低的转换成精度高的。例如一个double,一个long double时,将double转换成long double。一个int和一个float时,将int转换成float。

2、否则,如果两个操作数的类型都是带符号或无符号的整数,就把级别较低的操作数转换为另一个操作数类型 。从左到右从低到高(无符号和有符号级别一样): char,short,int,long,long long

3、判断转换成有无符号的,要看符号后面的类型的级别高低。例如 long 和一个unsign  int  将int转换成 sign long 。