1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
package cn.test;
import java.io.UnsupportedEncodingException;
public class Demo15 {
public static void main(String[] args) throws UnsupportedEncodingException {
String str = "你好ABC123" ;
byte [] b1 = str.getBytes(); //转换成字节系列用的是项目默认的编码
for ( byte b : b1) {
//把字节(转换成了int)以十六进制方式显示
System.out.print(Integer.toHexString(b & 0xff ) + " " );
}
System.out.println( "" );
//utf8编码,中文占用3个字节,英文和数字占用1个字节
byte [] b2 = str.getBytes( "utf8" );
for ( byte b : b2) {
System.out.print(Integer.toHexString(b & 0xff ) + " " );
}
System.out.println( "" );
//gbk编码,中文占用两个字节,英文和数字占用1个字节
byte [] b3 = str.getBytes( "gbk" );
for ( byte b : b3) {
System.out.print(Integer.toHexString(b & 0xff ) + " " );
}
System.out.println( "" );
//java是双字节编码 utf-16be
//utf-16be编码,中文占2个字节,英文和数字也占用2个字节
byte [] b4 = str.getBytes( "utf-16be" );
for ( byte b : b4) {
System.out.print(Integer.toHexString(b & 0xff ) + " " );
}
System.out.println( "" );
//当字节序列是某种编码时,这时候想把字节序列变成字符串,也需要用这种编码方式,否则会出现乱码
String str1 = new String(b4); //使用项目默认的编码
System.out.println(str1);
String str2 = new String(b4, "utf-16be" );
System.out.println(str2);
}
}
|
执行结果:
1
2
3
4
5
6
|
e4 bd a0 e5 a5 bd 41 42 43 31 32 33
e4 bd a0 e5 a5 bd 41 42 43 31 32 33
c4 e3 ba c3 41 42 43 31 32 33
4f 60 59 7d 0 41 0 42 0 43 0 31 0 32 0 33
O`Y}ABC123
你好ABC123
|
文件就是字节序列,可以是任意编码的字节序列。
如果我们在中文机器上直接创建文本文件,那么该文本文件只认识ansi编码(中文系统下,ansi编码代表gbk编码)
好了,以上所述是小编给大家介绍的Java IO流 文件的编码的实例代码,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
原文链接:http://www.cnblogs.com/tianxintian22/archive/2017/05/05/6813085.html