最初の項目を選択する必要があるリストの前提条件チェックの最適なパターンを知りたいです。
言い換えれば、リストはすべきではなくnull
、そのサイズは> 1であるべきだと思います。
この点で、グアバの checkPositionIndex は役に立たないことがわかりました。それどころか、直感に反すると思います。トリガーしないガードの後に概説されているように、checkArgumentではなくcheckPositionIndexを使用しているため、空のリストを爆破する以下の例を参照してください。
引数から .get(0) しても、位置 0 を確認するだけでは引数を検証するのに十分ではないようです。
import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkNotNull;
import static com.google.common.base.Preconditions.checkPositionIndex;
import java.util.List;
import com.google.common.collect.Lists;
public class HowShouldIUseCheckPositionIndex {
private static class ThingAMajig {
private String description;
private ThingAMajig(String description) {
this.description = description;
}
@Override
public String toString() {
return description;
}
}
private static void goByFirstItemOfTheseAMajigs(List<ThingAMajig> things) {
checkNotNull(things);
// Check whether getting the first item is fine
checkPositionIndex(0, things.size()); // Looks intuitive but...
System.out.println(things.get(0)); // Finally, help the economy!
checkArgument(things.size() > 0); // This would have worked :(
}
public static void main(String[] args) {
List<ThingAMajig> fullList =
Lists.newArrayList(new ThingAMajig(
"that thingy for the furnace I have been holding off buying"));
List<ThingAMajig> emptyList = Lists.newLinkedList();
goByFirstItemOfTheseAMajigs(fullList);
// goByFirstItemOfTheseAMajigs(emptyList); // This *bombs*
}
}