一个字符的String.length()是多少?
Java中,对于String.length(str),要看str的unicode对应的单元数。
原理
Java中 有内码和外码这一区分简单来说
内码:char或String在内存里使用的编码方式。
外码:除了内码都可以认为是“外码”。(包括class文件的编码)
java内码:unicode(utf-16)中使用的是utf-16
所以String.length():返回字符串的长度,这一长度等于字符串中的UTF-16的代码单元的数目。
UTF-16编码一个字符对于U+0000-U+FFFF范围内的字符采用2字节进行编码
而对于字符的码点大于U+FFFF的字符采用四字节进行编码,
前者是两字节也就是一个代码单元,后者一个字符是四字节也就是两个代码单元!
对于U+1D11E,它的代理单元是U+D834和U+DD1E
要统计字符数,可以使用codePointCount()
UTF-32 以 32 位一个单元,它只包含这一种单元就够了,它的一单元自然也就是四字节了。
UTF-8 的 8 指的就是最小为 8 位一个单元,也即一字节为一个单元
UTF-8 可以包含一个单元,二个单元,三个单元及四个单元,对应即是一,二,三及四字节。
Reference
https://juejin.cn/post/6844904036873814023