看到有人提问:
觉得有点意思,就研究了一下编码之间的转换,写了一小段程序
执行结果如何,大家可以执行一下这个程序
String heh="我爱我爱家";
byte[] bytes=heh.getBytes();
System.out.println(bytes.length);
结果是15
String heh="我爱我爱家";
byte[] bytes=heh.getBytes(“unicode”);
System.out.println(bytes.length);
结果是12
String heh="我爱我爱家";
byte[] bytes=heh.getBytes(“utf-8”);
System.out.println(bytes.length);
结果是15
觉得有点意思,就研究了一下编码之间的转换,写了一小段程序
package test.CharCode;
import java.io.UnsupportedEncodingException;
public class CodeTransfar {
/**
* 默认是utf-8
* @param str
* @param charset
* @param codeName
* @return
*/
public static String testCharset(String str, String charset,String codeName){
byte[] bytes = null;
String str1 = null;
System.out.print("字符串'"+str+"'的unicode码:");
for(char a : str.toCharArray()){
System.out.print("\\u"+Integer.toHexString((int)a));
}
System.out.println("\n");
try {
if("".equals(charset)){
bytes = str.getBytes();
}else{
bytes = str.getBytes(charset);
}
System.out.print("字符串'"+str+"'的'"+charset+"'码:");
for(byte b : bytes){
System.out.print(" "+Integer.toHexString(b&0xff));
}
System.out.println("\n");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
try {
if("".equals(codeName)){
str1 = new String(bytes);
}else{
str1 = new String(bytes,codeName);
}
System.out.println("str1:"+str1);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return str1;
}
public static void main(String[] args) {
String str = testCharset("a中文","US-ASCII","utf-8");
System.out.println(str);
}}执行结果如何,大家可以执行一下这个程序
本文通过一个简单的Java程序演示了不同字符编码(如UTF-8、Unicode等)下字符串的字节长度变化,并提供了源代码及运行结果分析。
785

被折叠的 条评论
为什么被折叠?



