使用 in 运算符将字符串与字符串范围进行比较
Using in operator to compare string with range of strings
我正在使用 in 运算符来检查值是否在范围内。但我无法准确理解与字符串范围的比较是如何完成的。以下是我尝试过的几个参数及其输出:
println("KOTLIN" in "J".."K")
false
println("KOTLIN" in "Java".."Scala")
true
println("KOTLIN" in "Java".."Bhuv")
false
in
被编译为以下函数(在 kotlin.ranges.Range.kt
中定义):
public operator fun contains(value: T): Boolean = value >= start && value <= endInclusive
所以 "KOTLIN" in "J".."K"
结果是:
("J".."K").contains("KOTLIN")
这种情况下的比较依赖于正常的 String
比较,因为 >= 和 <= 被编译为 compareTo
的变体。实现如下所示:
public int compareTo(String anotherString) {
int len1 = value.length;
int len2 = anotherString.value.length;
int lim = Math.min(len1, len2);
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2;
}
k++;
}
return len1 - len2;
}
因此,"KOTLIN" in "Java".."Scala"
等于以下内容:
"KOTLIN".compareTo("Java") >=0 && "KOTLIN".compareTo("Scala") <= 0
根据你的问题,我认为你对这个结果感到困惑:
println("KOTLIN" in "J".."K")
是 false
基本上,如果您要使用 Java 的字符串比较实现对这些进行排序,您会看到:
Bhuv
J
Java
K
KOTLIN
KZ
由于 K
在 KOTLIN
之前按字典顺序排列,因此您看到的结果完全合理。
我正在使用 in 运算符来检查值是否在范围内。但我无法准确理解与字符串范围的比较是如何完成的。以下是我尝试过的几个参数及其输出:
println("KOTLIN" in "J".."K")
false
println("KOTLIN" in "Java".."Scala")
true
println("KOTLIN" in "Java".."Bhuv")
false
in
被编译为以下函数(在 kotlin.ranges.Range.kt
中定义):
public operator fun contains(value: T): Boolean = value >= start && value <= endInclusive
所以 "KOTLIN" in "J".."K"
结果是:
("J".."K").contains("KOTLIN")
这种情况下的比较依赖于正常的 String
比较,因为 >= 和 <= 被编译为 compareTo
的变体。实现如下所示:
public int compareTo(String anotherString) {
int len1 = value.length;
int len2 = anotherString.value.length;
int lim = Math.min(len1, len2);
char v1[] = value;
char v2[] = anotherString.value;
int k = 0;
while (k < lim) {
char c1 = v1[k];
char c2 = v2[k];
if (c1 != c2) {
return c1 - c2;
}
k++;
}
return len1 - len2;
}
因此,"KOTLIN" in "Java".."Scala"
等于以下内容:
"KOTLIN".compareTo("Java") >=0 && "KOTLIN".compareTo("Scala") <= 0
根据你的问题,我认为你对这个结果感到困惑:
println("KOTLIN" in "J".."K")
是 false
基本上,如果您要使用 Java 的字符串比较实现对这些进行排序,您会看到:
Bhuv
J
Java
K
KOTLIN
KZ
由于 K
在 KOTLIN
之前按字典顺序排列,因此您看到的结果完全合理。