JDKソースコードを読むとき、作成者がパラメーターがnullかどうかを確認し、新しいNullPointerException()を手動でスローすることがよくあります。なぜ彼らはそれをするのですか?メソッドを呼び出すと新しいNullPointerException()がスローされるので、そうする必要はないと思います。(たとえば、HashMapのソースコードは次のとおりです:)
public V computeIfPresent(K key,
BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
if (remappingFunction == null)
throw new NullPointerException();
Node<K,V> e; V oldValue;
int hash = hash(key);
if ((e = getNode(hash, key)) != null &&
(oldValue = e.value) != null) {
V v = remappingFunction.apply(key, oldValue);
if (v != null) {
e.value = v;
afterNodeAccess(e);
return v;
}
else
removeNode(hash, key, null, false, true);
}
return null;
}
ArgumentNullException
そのような場合に(でなくNullReferenceException
)発生させる規則です-なぜNullPointerException
ここで明示的に(別のものではなく)発生させるのかについては、本当に良い質問です。