标签:十六进制 07 左移 C语言 算数 逻辑移位 34 十进制 移位
逻辑移位:不关注符号位(最高位),每个bit向左或者向右移位,最高位或者最低位由0补齐。
算数移位:关注符号位(最高位)。
算数左移:跟逻辑左移一样,每个bit向左移位,低位由0补齐。
算数右移:符号位(最高位)保持不变,每个bit向右移位,次高位由符号位补齐。
例子 1:逻辑移位和算数移位都一样的结果
十进制 34 :34 /16 = 2余2:十六进制 0x22:二进制 0010,0010
左移:二进制 0100,0100:十六进制 0x44:十进制 68
右移:二进制 0001,0001:十六进制 0x11:十进制 17
例子 2:算数移位
十进制 -34 :0010,0010取反后+1:二进制 1101,1110:十六进制 0xDE
左移:二进制 1011,1100:十六进制 0xBC:十进制 -68(减1后:1011,1011,取反后:0100,0100,0x44:68)
右移:二进制 1110,1111:十六进制 0xEF:十进制 -17(减1后:1110,1110,取反后:0001,0001,0x11:17)
从上面的两个例子看,算数移位和逻辑移位就是把某一个数字除2或者乘2。
但是需要注意这个结论的前提条件是不超过取值范围。
比如:signed char,取值范围是-128 ~ 127。
负数:1000,0000 ~ 1111,1111(-128 ~ -1),正数:0000,0000 ~ 0111,1111(1 ~ 127)
如果-34左移2位会怎样?是-34 * 2 * 2 = -136吗?不对的,因为-136已经超出了signed char取值范围了。
-34左移2位后:0111,1000。符号位都变了,变成了正数。十进制值:120(十六进制0x78)
标签:十六进制,07,左移,C语言,算数,逻辑移位,34,十进制,移位 来源: https://www.cnblogs.com/wuyuntana/p/14956927.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。