课堂练习:说出下面程序片段中编译错误或者可能产生计算溢出的部分
long l1=12345678,l2=8888888888;//这一句错误,long型后边要写L或者l,最好是L。
byte b3=129;//产生溢出,byte最大是127。
j=j+10;//错误,j没有指定初值。
i=i*0.1;//错误,i*0.1结果默认为double型,想赋值给i要用强制转换。
byte b=b1-b2;//错误,b1-b2结果是int型,赋给b要用强制转换。
char c=c1+c2-1;//错误,右面运算结果是int,要用强制转换赋值。
float f4=f1+f2*0.1;//错误,f2*0.1结果是double型,再加f1,结果仍然是double型,赋给f4要强制转换
double d=d1*i+j;//错误,j没有值,不能直接加。
1.b=16
2.不正确。理由如下:
代码中price*8/10,得出结果是int,要想赋给short型应强制转换。并且short是整型,只能表示整数,打完折的值可能不是整数,用short就无法表示。
public class DaZhe {
public static void main(String[] args) {
double price=101;
double realPrice=price*8/10;
System.out.println("原价为:"+price);
System.out.println("打折后的价格为:"+realPrice);
}
}
3.代码:
public class CaiPiao {
public static void main(String[] args) {
int ticketNumber;
byte a1,a2,a3,a4,a5;
Random random=new Random();
ticketNumber=(int)((Math.random()*89999+1)+10000);
System.out.println("彩票号码:");
System.out.println(ticketNumber);
a1=(byte)(ticketNumber/10000);
a2=(byte)(ticketNumber/1000%10);
a3=(byte)(ticketNumber%1000/100);
a4=(byte)(ticketNumber%100/10);
a5=(byte)(ticketNumber%10);
System.out.println(a1+a2+a3-a4+a5);
System.out.println(a1*a2*a3*a4*a5);
}
}