解决方案 »
- 如何替换不可见字符(回车13)
- SCJP如是说:Java里面都是值传递,疑惑
- java.lang.IllegalArgumentException是什么异常
- 初级问题:类集
- 在java应用程序中利用javax.comm可以实现来电显示号码的获取吗?
- 关于Applet的问题,高手请进,通过applet下载文件。
- 怎么设置jtable是可修改的?我的jtable不给我焦点。输入修改》?
- 我想控制java 程序运行的权限,policy文件是否有此功能。
- 关于response的一些问题
- 请大家讨论,来者有分,java中多个线程之间共享数据的方法都有哪些?
- C3P0 连接池问题
- 新手求教Eclipse使用的一个小问题
byte[] by = s.getBytes();
System.out.println(Integer.toString(a&0xff, 2));
//结果输出为11100100//-28
10111000//-72
10000000//-128
unicode 0100 ,1110 00,00 0000 根据utf-8的编码规则,输出正是“1”的unicode值。
String.getBytes的API描述:Encodes this String into a sequence of bytes using the platform's default charset。
其是与平台默认编码相关的。
在我的机器上,
System.out.println(Charset.defaultCharset().name());
输出为UTF-8,默认编码。
如表:
1字节 0xxxxxxx
2字节 110xxxxx 10xxxxxx
3字节 1110xxxx 10xxxxxx 10xxxxxx
4字节 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
5字节 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
6字节 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
因此UTF-8中可以用来表示字符编码的实际位数最多有31位,即上表中x所表示的位。除去那些控制位(每字节开头的10等),这些x表示的位与UNICODE编码是一一对应的,位高低顺序也相同。
实际将UNICODE转换为UTF-8编码时应先去除高位0,然后根据所剩编码的位数决定所需最小的UTF-8编码位数。
因此那些基本ASCII字符集中的字符(UNICODE兼容ASCII)只需要一个字节的UTF-8编码(7个二进制位)便可以表示。