我是靠谱客的博主 儒雅鸵鸟,最近开发中收集的这篇文章主要介绍二进制移动,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

二进制移动

1、算术左移-逻辑左移

算​术左移和逻辑左移一样都是右边补0:
 比如: 00101011​ 算术左移一位:01010110 
                逻辑左移一位​:01010110

对于二进制的数值来说左移n位等于原来的数值乘以2的n次方

 比如:00011010十进制是26,左移两位后是011010​00转成十进制是104恰好是26的4倍。

ps:这种倍数关系只适用于左移后被舍弃的高位不含1的情况,否则会溢出。

​2、 算术右移,逻辑右移

逻辑右移很简单,只要将二进制数整体右移,左边补0即可
 比如:10101101逻辑右移一位为01010110
算术右移符号位要一起移动,并且在左边补上符号位,也就是如果符号位是1就补1符号位是0就补0
 比如:11100算术右移一位为11110(符号位1跟着一起移动并且左边补了1)  

对于二进制的数值来说右移n位等于原来的数值除以2的n次方

比如10110100十进制是76(需要先将这个补码转换成原码之后再转换成十进制),右移两位后是11101101转成十进制是19恰好是76的4倍。  

3、算数移动逻辑移动的意义

算术左移和算术右移主要用来进行有符号数的倍增、减半;  
逻辑左移和逻辑右移主要用来进行无符号数的倍增、减半。

最后

以上就是儒雅鸵鸟为你收集整理的二进制移动的全部内容,希望文章能够帮你解决二进制移动所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(42)

评论列表共有 0 条评论

立即
投稿
返回
顶部