位运算符,内存

自动类型提升

前面的类型可以提升到后面的类型,后面的类型不能提升到前面的类型。容量小的类型和容量大的类型做运算时,结果会提升到容量大得类型,此时的容量指的是表示数范围的大和小。
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][];

同理如上,可以解释为什么必须指定行而不用指定列

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值