次のシナリオを検討してください。
String str = "str";
System.out.println("str subs: " + str.substring(3,3));
期待される結果:
StringIndexOutOfBoundsException
(beginIndex は文字列が終了した「後に」開始されるため)
実際の結果:
空の文字列が出力されます
String.javaから:
public String substring(int beginIndex, int endIndex) {
if (beginIndex < 0) {
throw new StringIndexOutOfBoundsException(beginIndex);
}
if (endIndex > count) {
throw new StringIndexOutOfBoundsException(endIndex);
}
if (beginIndex > endIndex) {
throw new StringIndexOutOfBoundsException(endIndex - beginIndex);
}
return ((beginIndex == 0) && (endIndex == count)) ? this :
new String(offset + beginIndex, endIndex - beginIndex, value);
}
beginIndex == endIndex == count
(count
は文字列の長さ)というエッジ ケースに実装が対応していないことは簡単にわかります。
マニュアルによると、メソッドの部分文字列:
この文字列の部分文字列である新しい文字列を返します。部分文字列は、指定された beginIndex で始まり、インデックス endIndex - 1 の文字まで拡張されます。したがって、部分文字列の長さは endIndex-beginIndex になります。
また、メソッドがスローすることも述べています。
IndexOutOfBoundsException - beginIndex が負の場合、または endIndex がこの String オブジェクトの長さより大きい場合、または beginIndex が endIndex より大きい場合。
case: as valid
を考慮することは理にかなっていますか? 何か不足していますか?beginIndex == endIndex == count