Post
#1
|
|
|
Grupa: Zarejestrowani Postów: 898 Pomógł: 48 Dołączył: 2.11.2005 Skąd: Poznań Ostrzeżenie: (0%)
|
Ostatnio ciekawi mnie temat używania Exceptionów - muszę przyznać, że trochę słabo to czuję. Kiedyś Exception stosowałem do rzeczy, które po prostu mogły spowodować niedziałanie aplikacji - np. brak dostępu do pliku czy coś podobnego. Ostatnio jednak widzę, że coraz częściej w nowych bibliotekach Exceptiony stosuje się w inny sposób tj. do wymuszenia typowania metody bez zwracania NULL.
Np taka klasa:
Pierwsza metoda (podejście o którym mówię) nigdy nie zwraca nulla, tylko obiekt lub rzuca wyjątek. Druga metoda (tradycyjna) zwraca obiekt lub null. Które podejście stosujecie? Dlaczego. Ja po rozmowie z kolegą zacząłem skłaniać się ku pierwszej wersji i brak możliwości zwrócenia oczekiwanego obiektu traktuję jako wyjątek.Podświadomie wydaje mi się to bardziej logiczne i wymusza trochę więcej dyscypliny. |
|
|
|
![]() |
Post
#2
|
|
|
Grupa: Zarejestrowani Postów: 898 Pomógł: 48 Dołączył: 2.11.2005 Skąd: Poznań Ostrzeżenie: (0%)
|
Co do kwestii przyzwyczajeń to trochę rozumiem bo też na początku mi się było trudno przestawić, ale w sumie kodu wychodzi podobnie i z perspektywy jednak kod oparty o wyjątki jest bardziej czytelny. Jeśli funkcja może zwrócić 2 rezultaty (null albo object) to zawsze jakoś trzeba to obsłużyć - albo if albo try catch. Try/catch (po przezywyczajeniu) wydaje mi się bardziej czytelny, jeśli oczywiście stosujemy szczegółowe wyjątki a nie \Exception. Oczywiście kwestia gustu - z tym nie dystkutuję.
Co do zwracania pustej kolekcji to to jest moim zdaniem inny przypadek niż brak obiektu, bo pusta kolekcja/tablica może być traktowana polimorficznie tak samo jak tablica/kolekcja z elementami. Tj. można po niej iterować, przekazać jako parametr dalej, zwracany typ też się zgadza itp., a z obiektem, który nie jest nagle obiektem tylko nullem już tego nie zrobisz. Moim zdaniem zwracanie function(): ?object trochę przeczy typowaniu - bo po to typuję zwracany typ, żeby nie musieć sprawdzać czy otrzymuję ten typ. Ale oczywiście to tylko moje zdanie i widzę też zalety "starego" podejścia. |
|
|
|
athabus Używanie Exceptionów a typowanie 31.12.2018, 14:04:37
Pyton_000 1-sza bo:
- rzucasz w 1 miejscu wyjątek
- zawsze ... 31.12.2018, 14:18:34
viking W pierwszym dodatkowo może polecieć type error jeś... 31.12.2018, 14:42:44
markonix Ja bym jednak wolał aby repozytoria zwracały puste... 31.12.2018, 15:10:21
Pilsener Jeśli przy próbie pobrania czegoś leci wyjątek, to... 31.12.2018, 17:11:46
athabus Haha nie rozawżajmy przypadków skrajnych jak ten z... 1.01.2019, 13:29:58 
Pilsener Cytat(athabus @ 1.01.2019, 13:29:58 )... 1.01.2019, 17:04:28
athabus Hej ale mamy XXI wiek i od takich rzeczy jest IDE ... 1.01.2019, 19:55:29
kapslokk Ja pozwolę sobie zostawić tutaj link: https://www.... 3.01.2019, 09:26:06
Crozin 1. Nie ma jednoznacznej odpowiedzi na pytanie null... 3.01.2019, 15:37:02
athabus @kapslokk - fajne slidy - sporo mi dały do myśleni... 3.01.2019, 16:14:36
Pyton_000 Co do race condition to przypomniała mi się moja d... 3.01.2019, 17:19:27 ![]() ![]() |
|
Aktualny czas: 17.12.2025 - 18:09 |