同学面试时被问到一个问题:-1右移两位是几呢,然后在他思考期间,面试官露出了奇怪的表情……所以赶快复习一下机器码及移位的相关知识
首先介绍一下概念与规则:
1、一般书写表示的数叫做真值,真值在计算机中的表示方式叫做机器码。
2、正整数用原码、反码、补码三种方式表示时完全一样,比如1(int型占4位)的原码、反码、补码都为00000000 00000000 00000000 00000001。
3、负整数用原码、反码、补码表示时,符号为都为1,用二进制表示的数值位各不相同。原码符号位为1不变,数值位按位取反得到反码,反码符号位不变,最低位加1得到补码。例如-1的原码为10000000 00000000 00000000 00000001,反码为11111111 11111111 11111111 11111110,补码为11111111 11111111 11111111 11111111
4、为什么机器码要用补码表示呢? 用补码表示可以将减法运算转化为加法运算,这样在计算机中运算时比较方便,不论数是正是负,机器总是做加法。如1-1在计算机中是00000000 00000000 00000000 00000001 + 11111111 11111111 11111111 11111111 = 00000000 00000000 00000000 00000000 = 0
移位运算:
"<<"左移:右边空出的位置补0,左移一位相当于乘以2。1左移一位即为00000000 00000000 00000000 00000001左移一位为0000000