我是靠谱客的博主 幸福热狗,最近开发中收集的这篇文章主要介绍有符号数的二进制数右移,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

把一个二进制数右移N位,规则为:
除符号位外,全部右移N位,
如果数字是一个无符号数值,则用0填补最左边的N位,
如果数字是一个有符号数值,则用1填补最左边的N位,
也就是说如果数字原先是一个正数,则右移之后在最左边补N个0;如果数字原先是个负数,则右移之后在最左边填补N个1。

例子:
0000 0010 >> 1 = 0000 0001 
0000 1010 >> 2 = 0000 0010
1000 0010 >> 1 = 1100 0001  
1000 1010 >> 3 = 1111 0001

上面的例子,正数的容易理解,为什么负数的是填补N个1呢,解释如下:
负数在计算机内部是以补码形式存放的,
1000 0010是一个负数,它的原码是1111 1110,也就是说它不是表示-2,而是表示-126;
证明1000 0010右移1位后是1100 0001呢,
1000 0010的原码是1111 1110,对原码右移1位,为1011 1111,(也就是-63),再换成补码,为1100 0001,
可以看出,1000 0010右移1位确实是1100 0001,也就是说,

换句话说,原码(正数)移位时,缺失位补0;

                  补码(负数)移位时,缺失位补符号位,当然正数时亦可(正数补码与原码完全一样)。

如果数字原先是个负数,则右移之后在最左边填补N个1。
 

最后

以上就是幸福热狗为你收集整理的有符号数的二进制数右移的全部内容,希望文章能够帮你解决有符号数的二进制数右移所遇到的程序开发问题。

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

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

评论列表共有 0 条评论

立即
投稿
返回
顶部