由于JAVA二进制基础那节课程讲解实在低于应该有的教学水平,故在此写下笔记。
*虽然是免费课程,但是我不认为这是一个该有的【教学】课程,我是一个很认真的人,所以我决定自己做笔记,自己找资料进行学习,这位老师也许是一个实战很强的人,但是人各有所长也各有所短,勿喷。
—————————————————————————————————
二进制基础
进制转换
-1(十进制)=0000 0001 -2(十进制)=0000 0010(1+1进一位)
-1字节(Byte)有8个二进制位(8bit),以后的笔记某些地方会省略前面的0000
-8(十进制)= 1000(二进制)、10(十进制)=1010(二进制)
-自己动手丰衣足食:自己写下1-10的二进制位加强记忆吧
1110100101(二进制)怎么算呢?
发现规律:2是10、4是100、8是1000、16是10000、32是100000、64是1000000、128是10000000
解:题中数字有10位
∵最高位是1(9个0)+1(8个0)+1(7个0)+0+1(5个0)+0+0+1(2个0)+1
∵1000000000+100000000+10000000+0(第6位没有)+100000+0+0(第4,3位没有)+100+1
∴把上面的数转化为十进制:512+256+128+32+4+1=933
1234(十进制)怎么算呢?
按照上一个问题的2最大幂次方的数字相加的方式,把题目数字加满为止
1234=1024+128+64+16+2 = 10011010010(1024有10个0,128有7个0,所以最前位是1001)
-自己动手丰衣足食:自己想一个二进制和一个十进制,分别把他们转化一下吧
与运算&
(对比的)两位都是1,结果才为1
0&0=0; 0&1=0; 1&0=0; 1&1=1;
例如:51&5 即转化为二进制进行对比↓0011 0011 &
0000 0101 =
0000 0001 ;
因此:51&5=1
*特殊用法:
1)清零:将一个单元清零,只需跟个位为0的数值相“与”
2)取一个数的指定位,只需1相“