Java中无论是汉字还是英文字母都是用Unicode编码来表示的,一个Unicode码是16位,每字节是8位,所以一个Unicode码占两字节。但是英文字母比较特殊,源自于8位(1字节)的ASCII吗,于是在Unicode码仅使用了低8位(1字节)就可以表示,高8位的话不使用也无所谓。所以 char c='a'; System.out.println(c.getBytes().lenth()),得到的是1(字节) 但汉字就完整地使用了16位(2字节)的Unicode,所以 char c='中'; System.out.println(c.getBytes().lenth()),得到的是2(字节) 综上,c='a'在内存中确实只占1字节,但这不意味着String s="abc"在内存中只占3字节。应该这么说,String s="abc"至少在内存中占3字节。这是因为char是基本数据类型,而String确是对象类型。