在java语言中,我们都知道默认使用的是Unicode编码格式,既每个字符占用两个字节,因此可以用来存储中文,我们看String源码可以看出,虽然String是由char所组成的,但是它采用了一种更加灵活的方式来存储,既英文占用一个字符,中文占用两个字符,采用这种存储方式的一个重要作用就是可以减少所需要的存储空间,提高存储效率,
我们来上代码
public class DemoTest {
public static void getLen(String str){
System.out.println(str+"的长度:"+str.length()+"所占字节数:"+str.getBytes().length);
}
public static void main(String[] args) {
String s1 = "Hello";
String s2 = "你好";
getLen(s1);
getLen(s2);
}
}
//打印输出
E:\java\bin\java.exe "-javaagent:D:\Program Files\JetBrains\IntelliJ IDEA 2018.3.2\lib\idea_rt.jar=2682:D:\Program Files\JetBrains\IntelliJ IDEA 2018.3.2\bin" -lang\commons-lang\2.6\commons-lang-2.6.jar com.mayikt.handler.controller.DemoTest
Hello的长度:5所占字节数:5
你好的长度:2所占字节数:6
在上面的例子当中,“Hello”是英文字符,因此所占自节数和字符串长度相同,“你好"字符串长度为2,由于每个字符都占用两个字节,因此总的字节数为4。