Zastanawiam się, jaka jest najlepsza metoda sprawdzania poprawności obiektów. Czy istnieje jakiś dodatkowy argument przeciwko sprawie pierwszej lub drugiej sprawie? Czy istnieje inny sposób?Proste sprawdzanie poprawności obiektów w Javie
Nie szukam żadnej biblioteki sprawdzania poprawności, po prostu chcę wykonać prostą weryfikację.
Case Jeden
class A {
public void doSomething(MyObject o) {
try {
validate(o);
doSomethingUseful(o);
} catch (ValidationException e) {
Logger.getLogger().warn(e);
}
}
private void validate(MyObject o) throws ValidationException
{
if (o.getXYZ() == null)
throw new ValidationException("Field XYZ cannot be null");
}
private void doSomethingUseful(MyObject o) { //some funny stuff }
}
Case Dwa
class A {
public void doSomething(MyObject o) {
if (validate(o)) {
doSomethingUseful(o);
} else
Logger.getLogger().warn("Object is invalid");
}
}
private boolean validate(MyObject o)
{
if (o.getXYZ() == null) return false;
return true;
}
private void doSomethingUseful(MyObject o) { //some funny stuff }
}
Brak silnych preferencji. Bardziej znaczące, być może, jest to, co robisz, aby móc uchwycić wiele wad walidacji na tym samym obiekcie, aby użytkownik nie musiał próbować w kółko, aby zobaczyć, co jest następną wadą. –
Dlaczego funkcja sprawdzania poprawności dla przypadku drugiego ma wartość "throws ValidationException", jeśli pracujesz z wartościami zmiennymi? –
@Damokles prawdopodobnie skopiować pastę – RMT