Java的toLowerCase()是否保留原始字符串长度? [英] Does Java's toLowerCase() preserve original string length?
本文介绍了Java的toLowerCase()是否保留原始字符串长度?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
假定两个Java String对象:
Assume two Java String objects:
String str = "<my string>";
String strLower = str.toLowerCase();
那么对于< my string>
的每个值,表达式是否正确
Is it then true that for every value of <my string>
the expression
str.length() == strLower.length()
评估为 true
?
那么, String.toLowerCase()
是否为任何String值保留原始字符串长度?
So, does String.toLowerCase()
preserve original string length for any value of String?
推荐答案
令人惊讶的是,它确实不!
Surprisingly it does not!!
来自 toLowerCase
使用给定语言环境的规则将此String中的所有字符转换为小写.大小写映射基于Character类指定的Unicode标准版本.由于案例映射并不总是1:1字符映射,因此生成的String的长度可能与原始String的长度不同.
示例:
package com.stackoverflow.q2357315;
import java.util.Locale;
public class Test {
public static void main(String[] args) throws Exception {
Locale.setDefault(new Locale("lt"));
String s = "\u00cc";
System.out.println(s + " (" + s.length() + ")"); // Ì (1)
s = s.toLowerCase();
System.out.println(s + " (" + s.length() + ")"); // i̇̀ (3)
}
}
这篇关于Java的toLowerCase()是否保留原始字符串长度?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文