[英]What is the correct alternative to Java's equalsIgnoreCase?
关于为什么以及何时java.lang.String.equalsIgnoreCase
因错误使用语言环境而失败的例子有很多很多。
但我没有找到任何正确方法的例子。 与java.lang.String.toUpperCase
不同,没有带语言环境参数的版本。 将两个字符串转换为大写或小写似乎都是浪费。 特别是当您正在进行大量比较的应用程序时。
在考虑区域设置和性能的情况下,进行忽略大小写字符串比较的正确方法是什么?
根据此页面 ,您可以使用Collator执行不区分大小写的相等性,如下所示:
//retrieve the runtime user's locale
Locale locale = new Locale(getUserLocale());
//pass the user's locale as an argument
Collator myCollator = Collator.getInstance(locale);
//set collator to Ignore case but not accents
//(default is Collator.TERTIARY, which is
//case sensitive)
myCollator.setStrength(Collator.SECONDARY);
int i = myCollator.compare(stringA,stringB);
(从以上网站复制......)
显然,在其他情况下,您可能会以不同的方式选择区域设置。
对于@fge - 这个Oracle Bug Report给出了一个发生的事情的例子。
可能的替代方案可能是滥用正则表达式。 这是动态更改字符串的性能密集型,但如果您要与常量进行比较,则可能是另一种选择:
Matcher matcher = Pattern.compile("^" + myOtherString + "$",
Pattern.CASE_INSENSITIVE | Pattern.LITERAL | Pattern.UNICODE_CASE).matcher();
if (matcher.matches(myString)) {
// ...
}
这将锚定您要比较的字符串,指定Literal字符串的Unicode感知不区分大小写的匹配。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.