[Java] String.length()
一个字符的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 可以包含一个单元,二个单元,三个单元及四个单元,对应即是一,二,三及四字节。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示