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

在Java中获取int的特定位子集

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

在Java中获取int的特定位子集

假设您有一个数字

n
,并希望从
i
j
(i = 5,j = 10)。

请注意,这

i=0
将为您提供最后一点

 int value = n & (((1 << (j-i)) - 1) << i );

会给你结果。

左侧很明显:您有一个值,并将在其上放置一个位掩码。

掩码的值是

((1 << (j-i)) - 1) << i
。它说:

  • 以一个
    1
    位(值
    0000000000000001
  • 左移
    j-i
    次数(值:2 ^(10-5)= 2 ^ 5 = 32 =
    0000000000100000
  • 减去1(值:31 =
    0000000000011111
    )-您是否看到最低位反转了?
  • 左移
    i
    次数(值:31 * 32 = 992 =
    0000001111100000

因此,您已经获得了5-10位的位掩码(更确切地说,是从5到9,因为不包括第10位)。



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

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

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