用Java将UTF-16转换为ASCII

用Java将UTF-16转换为ASCII,第1张

用Java将UTF-16转换为ASCII

这个怎么样:

String input = ... // my UTF-16 stringStringBuilder sb = new StringBuilder(input.length());for (int i = 0; i < input.length(); i++) {    char ch = input.charAt(i);    if (ch <= 0xFF) {        sb.append(ch);    }}byte[] ascii = sb.toString().getBytes("ISO-8859-1"); // aka LATIN-1

对于大型字符串,这可能不是最有效的转换方法,因为我们将字符复制了两次。但是,它具有简单明了的优点。

顺便说一句,严格来说,没有这样的字符集,例如8位ASCII。ASCII是7位字符集。LATIN-1是最接近“
8位ASCII”字符集的东西(Unipre的块0等效于LATIN-1),所以我假设这就是您的意思。

编辑:根据问题的更新,解决方案甚至更简单:

String input = ... // my UTF-16 stringbyte[] ascii = new byte[input.length()];for (int i = 0; i < input.length(); i++) {    ascii[i] = (byte) input.charAt(i);}

此解决方案效率更高。因为现在我们知道要期待多少字节,所以我们可以预先分配字节数组并复制(截断的)字符,而无需使用StringBuilder作为中间缓冲区。

但是,我不认为以这种方式处理错误数据是明智的。

编辑2:还有一个晦涩的“陷阱”。Unipre实际上将代码点(字符)定义为“大约21位”值… 0x000000到0x10FFFF
…并使用替代来表示> 0x00FFFF的代码。换句话说,Unipre代码点>
0x00FFFF实际上在UTF-16中表示为两个“字符”。我的回答或任何其他回答都没有考虑到这一点(深奥的)。实际上,在Java中处理>
0x00FFFF的代码点通常比较棘手。这是因为’char’是16位类型,而String是根据’char’定义的。

编辑3:也许处理不转换为ASCII的意外字符更明智的解决方案是用标准替换字符替换它们:

String input = ... // my UTF-16 stringbyte[] ascii = new byte[input.length()];for (int i = 0; i < input.length(); i++) {    char ch = input.charAt(i);    ascii[i] = (ch <= 0xFF) ? (byte) ch : (byte) '?';}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5131599.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-17
下一篇2022-11-17

发表评论

登录后才能评论

评论列表(0条)

    保存