参见英文答案 > Why is “out of range” not thrown for ‘substring(startIndex, endIndex)’ 6个
如果标题不清楚,我道歉.
现在,在字符串索引从0开始.例如:
Index 0 1 2 3 4
String H E L L O
在这种情况下,最后一个索引是4.
如果我想尝试做这样的事情:
System.out.println("hello".charAt(5));
它应该抛出一个“超出界限的索引”.
但是,如果我尝试运行以下代码:
System.out.println("hello".substring(5));
它确实运行!我写了类似的代码,后来注意到了,无法弄明白.
最终,问题是我们不应该达到这个指数的可能性如何?它允许我们写:
stringObj.substring(stringObj.length());
并且它看起来不太安全,因为stringObj.length()返回一个比最后一个索引多一个的整数.
它是故意制造的,这是否有目的?如果是这样,这个目的是什么,它带来了什么好处?
解决方法:
当你想到像这样的String中的索引时(例如字母在索引之间),使用子字符串更容易
H E L L O
0 1 2 3 4 5 <- possible range of indexes for HELLO
^ ^
| |
start length
(min index) (max index)
从a到b的子字符串时,只能获得这些索引之间的字符.
因此,对于“HELLO”.substring(2,4),你会得到
L L
2 3 4
返回“LL”.
现在在substring(5)的情况下,它与substring(5,length)相同,这意味着在这种情况下它是substring(5,5).因此,由于我们的模型中存在5个索引,因此它被认为是正确的,并且因为在5和5之间没有字符,所以我们得到空字符串作为结果.
类似的情况发生在substring(0,0)substring(1,1)等情况下,只要索引存在于我们的模型中.
StringIndexOutOfBoundsException仅在我们尝试访问不在我们模型中的索引时发生:
>负面的:-1,-2,……
>或大于长度6 7,…