自动类型提升
前面的类型可以提升到后面的类型,后面的类型不能提升到前面的类型。容量小的类型和容量大的类型做运算时,结果会提升到容量大得类型,此时的容量指的是表示数范围的大和小。
byte,char,short<int<long<float<double
当byte,char,short三种类型的变量做运算时,结果为int型
位运算符
位运算是直接对整数的二进制进行的运算。
左移右移
如21
二进制为0000 0000 0000 0000 0000 0000 0001 0101
如果将它左移两位,则移出标粗的两位,然后拿0在右边补上对应的两位
此时变为0000 0000 0000 0000 0000 0000 0101 0100为84
所以每向左移一位,相当于在原数的基础上乘2。
同理 往右移为除2.
但是细节和左移不一样,右移后,如果被移位的二进制最高位是0,则空缺位补0,如果最高位是1,空缺位补1。
>>>>
被移位二进制最高位无论是0或者1,空缺位都用0补。
&
二进制位进行&运算, 只有1&1时结果是1,其余都是0
|
二进制位进行|运算, 只有0|0时结果是0,其余都是1
^
异或,相同二进制位进行^运算,结果是0,不相同二进制位进行运算,结果为1
~
正数取反,各二进制码按补码各位取反。
负数取反,各二进制码按部位各位取反。
内存
栈
空间较小,存放局部变量
堆
空间较大,存放new出来的结构,
常量池
存放String
静态域
static
数组内存
一维数组
int[] arr = new int[]{1,2,3}
其中arr存放在栈中,new出来的int数组作为连续的内存存在堆里,arr在栈中的值为数组的内存地址。
二维数组
int[][] arr = new int[4][];
同理如上,可以解释为什么必须指定行而不用指定列