Java中的进制

1.Java的内置进制的转化

Integer.toBinaryString(int i);//将十进制转化为二进制

Integer.toOctalString(int i);//将十进制转化为八进制

Integer.toHexString(int i);//将十进制转化为十六进制

Integer.valueOf("100",2);//将二进制转化为十进制

Integer.valueOf("376",8);//将八进制转化为十进制

Integer.valueOf("FFF",16);//将十六进制转化为十进制

或者

Integer.parseInt("100",2);//将二进制转化为十进制

Integer.parseInt("376",8);//将八进制转化为十进制

Integer.parseInt("FFF",16);//将十六进制转化为十进制

  它们两个的区别:

A.parseInt在Api中public static int parseInt(String s,int radix)使用第二个参数指定的基数, 将字符串参数解析为有符号的整数。

例如:parseInt("0", 10) 返回 0      parseInt("473", 10) 返回 473      parseInt("-0", 10) 返回 0      parseInt("-FF", 16) 返回 -255

B.valueOf在Api中public static Integer valueOf(String s,int radix)使用第二个参数指定基数,它的作用和parseInt一样。他们唯一的区别是返回值不同,valueOf返回的是表示字符串指定的整数值的 Integer 对象。 而parseInt返回的是使用指定基数的字符串参数表示的整数。

2.Java中的进制

<1>数据类型转化为字节

例子:8143(00000000 00000000 00011111 11001111)

=>byte[]b=[-49,31,0,0]

第一个(低端)字节:8143>>0*8 & 0xff=(11001111)=207(或有符号-49)

第二个(低端)字节:8143>>1*8 & 0xff=(00001111)=31

第三个(低端)字节:8143>>2*8 & 0xff=(00000000)=0

第四个(低端)字节:8143>>3*8 & 0xff=(00000000)=0

那有什么叫做低端,其实是所谓的小端和大端:

小端法:低位字节排放在内存的地地址端即该值的起始地址,高位字节排放在内存的高地址端。

大端法:高位字节排放在内存的低地址端即该值的起始地址,低位字节排放在内存的高地址端

正如前面的那个例子它就是小端法

 

<2>字符串转化为字节数组

A.字符串->字节数组

 String s;

 Byte[] bs=s.getBytes();

B.字节数组->字符串

 Byte[] bs=new byte[int];

 String s=new String(bs);或者String s=new String(bs,encode);

//encode指的是编码方式为gb2312,utf-8

原文地址:https://www.cnblogs.com/dukc/p/4763922.html