Code review: 7012540 (java.util.Objects.nonNull() incorrectly named) (original) (raw)
Ulf Zibis Ulf.Zibis at gmx.de
Wed Jan 26 13:21:48 UTC 2011
- Previous message: Code review: 7012540 (java.util.Objects.nonNull() incorrectly named)
- Next message: Code review: 7012540 (java.util.Objects.nonNull() incorrectly named)
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
Am 26.01.2011 13:31, schrieb Ulf Zibis:
The funtionality is: Check the argument for non-nullity AND return it if the condition holds, otherwise fail by throwing NPE.
IIRC, Object.nonNull(x) was introduced to preserve the developer from repetitively coding: if (x == null) { throw new NullPointerException(); }
But isn't this not only half the rent? The 2nd part of the repetition is: try { ... } catch (NullPointerException npe) { doAlternatively(); }
I think, in case of an expected null value, the developer has a specific idea, how to handle it. Just throwing an exception should be reserved for _un_expected cases.
So something like "nullChecked(x, runnable)" could serve the full rent. Fairly this should be delayed to closures.
-Ulf
- Previous message: Code review: 7012540 (java.util.Objects.nonNull() incorrectly named)
- Next message: Code review: 7012540 (java.util.Objects.nonNull() incorrectly named)
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]