java 实现取int型的第二个字节的数

网友投稿 279 2022-11-04

java 实现取int型的第二个字节的数

目录取int型的第二个字节的数1.首先创建 Bytebuffer2.通过位运算计算3.附一个int转byte数组int的取值范围例如7的二进制表示形式为例如-7的二进制表示为

取int型的第二个字节的数

无意中看到某个题目,前提条件,一个byte最多表示256位,因为其是由8个位表示 ,八个1 最多表示256位。

一个int由32位组成,所以是4个byte表示。题目要求是给定一个int数字,问第二个byte是多少。刚开始不会写。

再后来复习nio时,突然想到这题。

1.首先创建 Bytebuffer

其内部是由byte组成的数组。因为我们保存一个int 只需要创建一个大小为4byte的即可。下面看代码。

public static void main(String[] args) throws IOException {

ByteBuffer bb=ByteBuffer.allocate(4); //创建大小为4的byteBuffer

bb.asIntBuffer().put(5566); //以int视图将任意int数存进去

System.out.println(Arrays.toString(bb.array())); //打印出改bytebuffer,其中想要第几个byte就取出就好了

}

结果

[0, 0, 21, -66]

2.通过位运算计算

首先

int  a=5566;

a=a>>8;

a=a&0xff;

得到的a就是 第二位的值

3.附一个int转byte数组

private static byte[] intToByte(int in){

byte [] b=new byte[4];

b[3]= (byte) (in&0xff);

b[2]= (byte) (in>>8 &0xff);

b[1]= (byte) (in>>16 &0xff);

b[0]= (byte) (in>>24 &0xff);

return b;

}

int的取值范围

int型的数据字节长度是4,一共是32位,第一位用于表示正负号,其他位的数字组成它所代表的值,

例如7的二进制表示形式为

00000000 00000000 00000000 00000111

当表示负数的时候,则采用的是补码的形式,第一位是1,

例如-7的二进制表示为

11111111 11111111 11111111 11111001

int型数据的取值范围:-2^31—-2^31-1

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:shell条件语句
下一篇:可信计算框架中是如何实现保密功能的
相关文章

 发表评论

暂时没有评论,来抢沙发吧~