-
Data: 2019-01-03 09:37:41
Temat: Re: Jaki język polecić początkującemu? - komentarz do artykułu w Programista 9/2018
Od: Maciej Sobczak <s...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]> > > Jak to kiedyś powiedział mój kolega,
> > > "nikt, kto kroi chleb, nie myśli, że wysyła wiadomość do noża,
> > > nakazującą mu krojenie chleba, albo do chleba, nakazującą
> > > mu się pokroić".
> >
> > Zły poziom abstrakcji.
>
> Kto decyduje o tym, jaki poziom abstrakcji jest dobry, a jaki zły?
Twój kolega. Zauważył, że nie wysyła się wiadomości do noża.
> > Pomyśl, o zespole kucharzy, którzy wydają sobie właśnie takie polecenia. Dlaczego
wtedy to ma sens?
>
> A wtedy to ma sens?
- Hej, młody, pokrój chleb.
Jak najbardziej ma sens.
> Do ludzi mówimy na różne sposoby, i oni na różne sposoby reagują.
> Obgadują się, zawierają sojusze, proponują rozwiązania, i potrafią
> się obrazić, jak im ktoś będzie wydawał rozkazy.
> Po obiektach w językach obiektowych raczej oczekuje się przewidywalności
> i bezwzględnego posłuszeństwa.
Właśnie. Dlatego mówimy, że w języku obiektowym *modelujemy* jakiś system a nie
odtwarzamy rzeczywistość. Model z natury jest zawsze uproszczony.
Gdzieś jednak jest granica abstrakcji, której przekroczenie nie wnosi wartości
dodanej. Nie wysyłamy komunikatu do zmiennych całkowitych, żeby się do siebie dodały.
I nie wysyłamy komunikatu do noża, żeby pokroił chleb. Ale do elektrycznej krajalnicy
wysyłamy, naciskając guzik na jej froncie. Być może w środku krajalnicy jest jakiś
nóż, ale nas to nie obchodzi, bo to nie jemu wysyłamy komunikat. I w ogóle obudowa z
guzikiem jest po to, żebyśmy nie wnikali, co tam w środku jest. Dla nas jest guzik na
tej obudowie - właśnie po to, żebyśmy mogli tej krajalnicy wysłać komunikat.
Widzisz już o co chodzi?
Programowanie obiektowe jest po to, żeby czytelnie modelować rzeczywiste systemy.
Oczywiście, jak każde narzędzie, to też może być źle użyte. Np. na złym poziomie
abstrakcji.
--
Maciej Sobczak * http://www.inspirel.com
Następne wpisy z tego wątku
- 03.01.19 09:44 Maciej Sobczak
- 03.01.19 09:57 Maciej Sobczak
- 03.01.19 14:19 g...@g...com
- 03.01.19 14:34 g...@g...com
- 03.01.19 17:15 Roman Tyczka
- 03.01.19 17:24 AK
- 03.01.19 17:30 g...@g...com
- 03.01.19 17:44 AK
- 03.01.19 18:20 g...@g...com
- 03.01.19 19:37 g...@g...com
- 03.01.19 21:51 fir
- 03.01.19 22:21 g...@g...com
- 04.01.19 01:13 fir
- 04.01.19 02:00 AK
- 04.01.19 09:20 Maciej Sobczak
Najnowsze wątki z tej grupy
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-12-04 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2024-12-04 Czy policjantów należy ROZBROIĆ?
- 2024-12-03 Tymoteusz Sz.
- 2024-12-03 Re: Prezydent ułaskawia: Prezydent USA Biden (D) ułaskawia syna własnego
- 2024-12-03 Re: Tani dodatkowy sim do smartwacha
- 2024-12-03 Wróblewo => Analityk finansowy <=
- 2024-12-03 Praktyczny test GPS...
- 2024-12-02 Tak się sprzedają elektryczne woldzwageny ;-)
- 2024-12-02 Akumulator do Hyundai
- 2024-12-02 Olsztyn => Sales Specialist <=
- 2024-12-02 Poznań => Technical Artist <=
- 2024-12-02 Bieruń => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-02 Kraków => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2024-12-02 Chrzanów => Team Lead / Tribe Lead FrontEnd <=
- 2024-12-02 Białystok => Delphi Programmer <=