我创建了一个Java程序来比较两个字符串:
String str = "Hello";
if (str.equals("hello")) {
System.out.println("match");
} else {
System.out.println("no match");
}
它是大小写敏感的。我怎样才能改变它,使其不区分大小写?
我创建了一个Java程序来比较两个字符串:
String str = "Hello";
if (str.equals("hello")) {
System.out.println("match");
} else {
System.out.println("no match");
}
它是大小写敏感的。我怎样才能改变它,使其不区分大小写?
最好的方法是使用str.equalsIgnoreCase("foo")
。它专门针对这个目的进行了优化。
你也可以在使用equals
比较之前将两个字符串转换为大写或小写。这是一个有用的技巧,值得记住,因为其他语言可能没有equalsIgnoreCase
的等效功能。
str.toUpperCase().equals(str2.toUpperCase())
如果你使用的是非罗马字母表,请注意JavaDoc中equalsIgnoreCase
这部分的内容,其中指出:
请注意,该方法不考虑语言环境,并且对于某些语言环境会导致不理想的结果。 Collator类提供了区域设置敏感的比较。
可使用String.equalsIgnoreCase()
方法。
要查找此类答案,请使用Java API参考文档:
String.equalsIgnoreCase
是处理简单不区分大小写字符串比较最实用的选择。
但是,需要注意的是该方法既不能进行完整的大小写折叠,也不能进行分解,因此无法执行Unicode标准中指定的无大小写匹配。 实际上,JDK API没有提供访问大小写折叠字符数据的信息,因此最好将此任务委托给经过验证的第三方库。
这个库就是ICU,下面是如何实现一个用于不区分大小写字符串比较的实用程序:
import com.ibm.icu.text.Normalizer2;
// ...
public static boolean equalsIgnoreCase(CharSequence s, CharSequence t) {
Normalizer2 normalizer = Normalizer2.getNFKCCasefoldInstance();
return normalizer.normalize(s).equals(normalizer.normalize(t));
}
String brook = "flu\u0308ßchen";
String BROOK = "FLÜSSCHEN";
assert equalsIgnoreCase(brook, BROOK);
仅使用String.equalsIgnoreCase
或者将字符串转为大写或小写后使用String.equals
进行比较,即使这个简单的测试都无法通过。
(需要注意的是,预定义的大小写折叠规则getNFKCCasefoldInstance
不依赖于特定的语言环境;但对于土耳其地区,则需要更多涉及到UCharacter.foldCase
的工作)。
您需要使用String
对象的compareToIgnoreCase
方法。
int compareValue = str1.compareToIgnoreCase(str2);
if (compareValue == 0)
这意味着str1
等于str2
。
import java.lang.String; //contains equalsIgnoreCase()
/*
*
*/
String s1 = "Hello";
String s2 = "hello";
if (s1.equalsIgnoreCase(s2)) {
System.out.println("hai");
} else {
System.out.println("welcome");
}
现在它将输出:hai
在默认的Java API中,您有:
String.CASE_INSENSITIVE_ORDER
String s = "some text here";
s.equalsIgnoreCase("Some text here");
您希望在自己的代码中进行纯等式检查。
仅为进一步了解有关Java中字符串相等性的信息。java.lang.String类的hashCode()函数“区分大小写”:
public int hashCode() {
int h = hash;
if (h == 0 && value.length > 0) {
char val[] = value;
for (int i = 0; i < value.length; i++) {
h = 31 * h + val[i];
}
hash = h;
}
return h;
}
如果你想使用Hashtable/HashMap作为字符串键,并且希望"somekey"、"SomeKey"和"SOMEKEY"被视为相等的键,那么你必须将字符串包装在另一个类中(不能继承String,因为它是一个 final 类)。例如:
private static class HashWrap {
private final String value;
private final int hash;
public String get() {
return value;
}
private HashWrap(String value) {
this.value = value;
String lc = value.toLowerCase();
this.hash = lc.hashCode();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o instanceof HashWrap) {
HashWrap that = (HashWrap) o;
return value.equalsIgnoreCase(that.value);
} else {
return false;
}
}
@Override
public int hashCode() {
return this.hash;
}
}
HashMap<HashWrap, Object> map = new HashMap<HashWrap, Object>();
public boolean areStringsSame(String str1, String str2)
{
if (str1 == null && str2 == null)
return true;
if (str1 == null || str2 == null)
return false;
return str1.equalsIgnoreCase(str2);
}
if (str1 == null || str2 == null) return false;
。 - LuckyMeif (str1 == str2) return true;
,这既考虑了空值的情况,又避免了两个字符串引用指向同一个字符串对象的情况。 - Barneys1.equalsIgnoreCase(s2)
: https://docs.oracle.com/javase/1.5.0/docs/api/java/lang/String.html#equalsIgnoreCase(java.lang.String)。org.apache.commons.lang.StringUtils.equalsIgnoreCase(String, String)
或者
org.apache.commons.lang3.StringUtils.equalsIgnoreCase(CharSequence, CharSequence)
s1.equalsIgnoreCase(s2)
,你可能会在需要执行的所有地方都失败。我建议你找出字符串来自哪里——文件、数据库或用户输入——然后将其转换为大写(或小写),并继续使用.equals
进行比较。 - H2ONaClequalsIgnoreCase
方法。请阅读土耳其语 I 问题和类似的 Unicode 问题以了解原理。 - Ohad SchneiderequalsIgnoreCase
对于土耳其语返回错误的值,因为它在比较 "i" 和 "I" 时返回 true,即使它应该返回 false。因此,我怀疑如果您想考虑区域设置,那么Collator
实际上是正确的选择。 - HakanaitoLowerCase
/toUpperCase
和逐个字符执行会产生两个不同的结果。 - Hakanai