一、模问题
1.负数模整数,结果为负数,例:-5%2 = -1;
2.正数模负数,结果为正数,例:5%(-2)=1;
3.负数模负数,结果为负数,例:-5%(-2)=-1;
4.0模任何数结果为0,例:0%5 = 0;
二、自增、减问题
1.
三、强制类型转换
1.System.out.println(‘a’+0),输出=97;
2.任何以整数出现的数据,默认都是int类型
如:byte a= 4; 其中4就是一个int类型,但由于在编译过程中,编译器会自动判断 4 是不是在byte 范围内,若是,会自动舍弃前三字节,相当于系统自动进行强制类型转 换,将int整数4转换为byte类型。
3. byte a=4,b=3,c;
c=a+b,编译出错,因为a和b虽然是两个byte变量,但在进行a+b求和时,编译器会自动把byte类型数据转换成int类型,故a+b的结果会是一个int型,而将一个int型赋值给byte,就会出错,因为两个类型的字节不同,int是4个字节,byte是一个字节,字符是2个字节 char ch ='你'是对的,因为一个汉字是两个字节。
总结:1.两个变量相加,先对类型进行提升,然后运算,再将运算结果赋值。
2.两个常量相加,先计算常量数值,然后判断是否满足类型范围,再赋值。
四、自增/减问题
1. byte i=0,j;
i=i++;输出i等于0;首先,系统分配一个临时缓存区,假设为temp,首先temp=i=0,然后i自增变成1,然后i=temp,所以i的结果为0而不是1.
i=++i;输出i等于1;首先,i自增变成1,然后系统分配一个临时缓存区,假设为temp,temp=i=1,然后i=temp,所以i的结果为1而不是0.
五、赋值运算
1.byte i=3,j;
i+=1;和 i = i+1的区别,1)i = i + 1;会出错,而 i+=1;不会,因为 i +=1相当于是 i =1,系统会判断1是不是在byte范围内,是进行的一次计算,而 i = i+1;是两次计 算。就有字节不同的问题。
2 )+=会自动进行byte类型转换,而=的左边会自动进行类型提升,即变成int型。所以一个通过,一个不能通过。
3 ) i += j;也不会出错,因为编译器内部对于+=默认会有字节转换,即将j转换成byte类型。
六、小问题:
1.‘a’+0 =97,编译器会自动把字符变成int型的数值,即'a'变成整数97。
2.‘7’-'0'= 7
3.负数变成二进制数,就是负数的绝对值的二进制数取反加1,负数的二进制最高位为1,二正数为0;