栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

>>在Java中做什么?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

>>在Java中做什么?

计算机是二进制设备。因此,数字由1和0的序列表示。

移位只是简单地左右移动那些1和0的序列。

因此,

>>
操作员要做的就是将这些位向右移一位。

考虑数字101:

// Assuming signed 8-bit integers01100101 // How 101 is represented in binary00110010 // After right shifting one bit, this represents 50

在这种情况下,最低有效位被截断了。显然,细节决定了魔鬼,但这就是全部。

<<
操作者不相反的操作:

// Assuming signed 8-bit integers01100101 // How 101 is represented in binary11001010 // After left shifting one bit, this represents -54// Assuming unsigned 8-bit integers01100101 // How 101 is represented in binary11001010 // After left shifting one bit, this represents 202

在这种情况下,由于我只使用8位,所以最高位被截断了。但是,如果该数字有更多位,请执行以下操作:

// Assuming signed 16-bit integers00000000 01100101 // How 101 is represented in binary00000000 11001010 // After left shifting one bit, this represents 20200000001 10010100 // After left shifting one bit again, this represents 404

因此,根据要处理的位数和与之相关的数据类型,您可能会获得不同的数字。

附录: 如果您想知道二进制的工作方式,请考虑十进制系统的工作方式。考虑数字5287。可以这样写:

5287

但是您也可以这样写出来:

5287 = (5 * 1000) + (2 * 100) + (8 * 10) + (7 * 1)

然后可以这样写出来:

5287 = (5 * 10^3) + (2 * 10^2) + (8 * 10^1) + (7 * 10^0)

上面的等式解释了为什么十进制数系统有时被称为以10为底的系统。十进制数字系统使用10位数字(0-9)。注意指数如何与数字位置相对应。

二进制数字系统或以2为基的系统是完全相同的东西,但是数字2是指数的基础,并且仅使用两个数字:0和1。

5287 = 00010100 10100111 (base 2)     = (0 * 2^15) + (0 * 2^14) + (0 * 2^13) + (1 * 2^12)     + (0 * 2^11) + (1 * 2^10) + (0 * 2^9)  + (0 * 2^8)     + (1 * 2^7)  + (0 * 2^6)  + (1 * 2^5)  + (0 * 2^4)     + (0 * 2^3)  + (1 * 2^2)  + (1 * 2^1)  + (1 * 2^0)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/595215.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号