我是靠谱客的博主 笑点低黄豆,最近开发中收集的这篇文章主要介绍负数的移位、有符号数的移位转换为无符号数的移位,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  • 对于计算机而言,用 32 去乘一个数,并非真的去乘,而是移动二进制的 5 位,显然是十分容易。(对于计算机没有 10 进制的概念,本质上都是 2 进制)

1. 负数移位的等价变换

注意,负数右移不等价于正数右移的结果取负号,即 a>>b ≠ -((-a)>>b),等价于 ~(~a>>b)

2. 有符号数的移位转换为无符号数的移位

  • 有符号数的左移,无符号数的左移,均不考虑符号位,均为逻辑移位,故可直接进行类型的强转:
    • 如果 a 为有符号数,a << b 可等价转换为,(signed)(unsigned)a << b);
  • 有符号的右移,会保持符号,如果将有符号数强转为符号数,再右移时,左侧是补零的,将会出现不一致;
    • 如果 a 为有符号数,a >>b 可等价转换为,(signed)(~((~(unsigned)a)>>b))

最后

以上就是笑点低黄豆为你收集整理的负数的移位、有符号数的移位转换为无符号数的移位的全部内容,希望文章能够帮你解决负数的移位、有符号数的移位转换为无符号数的移位所遇到的程序开发问题。

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

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

评论列表共有 0 条评论

立即
投稿
返回
顶部