标签:
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
标签:
原文地址:http://www.cnblogs.com/dukc/p/4763922.html