-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!news.chmurka.net!.POSTED!not-for-mail
From: Andrzej Jarzabek <a...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: Jakie typowanie jest najlepsze i dlaczego statyczne?
Date: Mon, 11 Feb 2013 23:19:46 +0000
Organization: news.chmurka.net
Lines: 176
Message-ID: <kfbuak$lvs$1@somewhere.invalid>
References: <f...@g...com>
<3...@b...softax.pl>
<b...@g...com>
<k...@b...softax.pl>
<4...@g...com>
<keun5d$lsh$1@somewhere.invalid>
<f...@g...com>
<keuri4$nje$1@somewhere.invalid>
<1...@g...com>
<keuusd$ovj$1@somewhere.invalid>
<7...@g...com>
<kf1b5r$cvj$1@somewhere.invalid>
<51152b96$0$1306$65785112@news.neostrada.pl>
<3...@x...googlegroups.com>
<4...@g...com>
<kf61vl$fh0$1@somewhere.invalid>
<c...@g...com>
<kf8mrj$piq$1@somewhere.invalid>
<3...@g...com>
<kf9c7i$61o$1@somewhere.invalid>
<8...@g...com>
NNTP-Posting-Host: 5ac53cfe.bb.sky.com
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: somewhere.invalid 1360624788 22524 90.197.60.254 (11 Feb 2013 23:19:48 GMT)
X-Complaints-To: abuse-news.(at).chmurka.net
NNTP-Posting-Date: Mon, 11 Feb 2013 23:19:48 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130107
Thunderbird/17.0.2
In-Reply-To: <8...@g...com>
X-Authenticated-User: ajarzabek
Xref: news-archive.icm.edu.pl pl.comp.programming:202015
[ ukryj nagłówki ]On 11/02/2013 09:49, Maciej Sobczak wrote:
> W dniu poniedziałek, 11 lutego 2013 00:58:41 UTC+1 użytkownik Andrzej
> Jarzabek napisał:
>
>>> Co z tego, że pokazuje, skoro przez swoją dynamiczność nie dałbym
>>> mu szansy się wykazać.
>>
>> To jest argument nazasadzie: "może i ta cała obiektowość ma jakieś
>> zalety przy pisaniu dużych systemów, ale co z tego, skoro nidgy bym
>> nie zdecydował się użyć jej do pisania czegoś takiego".
>
> Tak, to jest dokładnie taki argument.
No to odpowiem: ty nie dałbyś, ale kto inny dał. Tajemnica wyjaśniona?
> Poza tym, że obiektowość powstała z myślą o dużych systemach
W którym momencie?
> i sama w sobie nie ma cech, który by były z nimi sprzeczne.
http://c2.com/cgi/wiki?ArgumentsAgainstOop
http://folk.uio.no/andersmo/oo.html
>>>> Pozwala, ale są inne sposoby, które też pozwalają.
>>> Droższe?
>>
>> Nie wiem nawet, jak to porównać. Chodzi o zupełnie inny paradygmat
>> pisania programów,
>
> Droższy? Bardziej efektywny? Czy jedynie "też pozwala"?
Zapewne zależy kto, co i w jakim języku.
> Jeśli coś ma być inaczej, to ma być po coś i ma się opłacać.
A dlaczego akurat to dynamiczny, a nie statyczny system typów to jest
"inaczej"?
>>> Jak do tej pory jedyny code reuse między różnymi typami widywałem
>>> w kontenerach
>>
>> To niewiele widziałeś.
>
> Możliwe, ale nie czuję się tym pokrzywdzony a skoro tak, to
> najwyraźniej nic nie straciłem, że nie widziałem. Poproszę o lepszy
> argument, niż "niewiele widziałeś".
Poproszę o lepszy argument, niż "nie widziałem".
>> Żeby nie było: w C++ da się osiągnąć niezły code reuse, ale czasem
>> sensowne zrobienie tego wymaga ostrego lawirowania między
>> dziedziczeniem klas a szablonami.
>
> Statyczne typowanie ma swój koszt. Pytanie, jaki jest końcowy
> bilans.
I uważasz, że potrafisz ten bilans policzyć?
>>> Innym przykładem może być np. serializacja, ale ponieważ temat
>>> serializacji pojawia się w systemach rozproszonych, które zwykle
>>> są heterogeniczne, to i tutaj mało mnie interesuje, co mi ma do
[...]
>> Można tak zrobić system rozproszony, żeby nie był heterogeniczny.
>
> Dlaczego? Po co? Żeby móc powiedzieć, że jakiś jeden język jest OK?
Na przykład dlatego, że nie ma potrzeby robić go heterogenicznym, a
heterogeniczność pociąga koszta.
> Jednym z celów rozpraszania jest wykorzystanie zalet różnych
> technologii, bo różne technologie mają swoje mocne punkty w różnych
> częściach całości.
Ale to tylko jeden z celów. Są inne powody, jak wykorzystanie zasobów
(mocy obliczeniowej, pamięci, dysku, przepustosości połączeń
sieciowych), wysoka niezawodność (redundancja), globalne rozproszenie
(żeby klient ze Stanów nie musiał się łączyć z serwerem w Europie) i tak
dalej.
Poza tym pozostańmy nawet przy heterogeniczności. Dość popularnym
rozwiązaniem z językami dynamicznymi jest Javascript w przeglądarce i
jakiś Python czy inny Ruby na serwerze. W celu serializacji obiektów i
przesyłania ich przez sieć wymyślono format JSON - dzięki niemu można z
łatwością serializować dane w Pythonie i przesyłać do javascriptowego
klienta lub odwrotnie. Można to spokojnie robić bez potrzeby
uzgadaniania definicji typów pomiędzy serwerem a klientem - każda strona
korzysta z tych właściwości, jakich potrzebuje, i każda jest w stanie
wziąć odserializowany obiekt i zserializować go z powrotem razem ze
wszystkimi polami/właściwościami, nawet jeśli nie były one jeszcze
zdefiniowane w momencie pisania tego kodu.
> Czyli znowu mamy podobny argument: co z tego, że język dynamiczny
> daje fajną serializację w homogenicznym systemie rozproszonym, skoro
> nie robię homogenicznych systemów rozproszonych. Ten argument może
> być niewygodny, ale jest realny i oznacza, że w realu wartość dodana
> dynamicznego systemu typów jest mniejsza, niż się reklamuje.
Argument, że czegośtam nie robisz jest tyle realny, co mało znaczący.
Dla każdej rzeczy istnieje taki ktoś, kto jej nie robi.
>> Poza tym jest też taki dyanmiczny język specjalnie zaprojektowany
>> do pisania homogenicznych systemów rozproszonych jakim jest
>> Erlang.
>
> I jego też nie użyję z powodu tego samego argumentu?
>
> Tak, wiem, że ktoś takie systemy pisze. Ale *ja* nie piszę, więc
> Erlang rozwiązuje problem, którego nie mam a tych, które mam, nie
> rozwiązuje.
No ale przecież ja się o twoich problemach nie wypowiadam. Chyba że, jak
M.M. uważasz, że jak tobie coś nie jest potrzebne, to w ogóle nie jest
potrzebne.
BTW można się zastanowić nad faktem, że dynamicznie typowany Erlang jest
przeznaczony do, i używany w systemach wysokiej niezawodności.
>>>> loose coupling
>>> Daję radę bez dynamicznego systemu typów.
>> Nie chodzi o to, czy daje radę, tylko czy jest wygodne, łatwe i
>> proste.
>
> Całe programowanie obiektowe powstało po to, żeby mieć loose
> coupling, więc nie widzę tu problemu. Realizacja OO w mainstreamowych
> językach sprawia, że jest to zarówno wygodne, łatwie i proste.
Nie jest. Prosty przykład - w C++ nawet niewielka zmiana definicji typu
danych między biblioteką a programem z niej korzystającym może
spowodować spektakularne wylecenie wszystkiego w powietrze. W Javie jest
trochę lepiej, ale próby ładowania różnych wersji klasy też mogą się
niedobrze skończyć. No i oczywiście rozpraszanie czegokolwiek to osobny
cyrk, wymagający opakowania w wiele warstw, IDL-i, WSDL-i, XML schema i
nie wiadomo czego jeszcze.
>> W jęyku dynamicznie typowanym też nie potrzebujesz takiego unit
>> testu, bo skoro masz test, który testuje, to, co robi foo, kiedy
>> wywołuje bar z tą liczbą parametrów, to on automatycznie sprawdza
>> też, że może zawołać z taką listą, z jaką woła.
>
> Zakładając pokrycie 100%. Bo tylko wtedy faktycznie zawoła. Testy z
> pokryciem 100% są bardzo kosztowne.
Nie musisz mieć pokrycia 100%, wystarczy pokrycietego kawałka kodu, w
którym foo woła bar. To nie powinno być takie trudne, bo jako
programista wiesz przecież, dlaczego foo woła bar (jeśli nie wiesz, to
statyczne typowanie cię nie uratuje) i w związku z tym niezależnie od
tego, czy woła i z jakimi parametrami masz unit test testujący ten
kawałek funkcjonalności foo.
Poza tym niemal 100% pokrycie unit testami (z wyjątkiem cienkich warstw
owijających przekraczanie granic systemu, które można pokryć integration
testami) jest bardzo tanie, jeśli stosuje się TDD. A ponieważ w
większości przypadków TDD jest tańsze niż alternatywy, to wysokie
pokrycie unit testami jest po prostu tak tanie, że aż ma koszt ujemny.
>>> Nabijam się, ale na poważnie: nie raz dostałem po gałach różnymi
>>> komunikatami, które ładnie zdradzały w czym dany serwis został
>>> ulepiony, więc potwierdzam: faktycznie, masz rację, pisze się.
>> I co, wyjątków z Javy nie widujesz?
>
> A czy ja gdzieś w tej dyskusji napisałem, że Java jest dla mnie
> statycznym językiem?
W myśl powszechnie rozumianego podziału na dynamiczne i statyczne
systemy typów, Java jest językiem o typowaniu statycznym.
> (Wyprzedzam następne pytanie: w C++ i w Adzie też wyjątki widuję.)
Na stronach WWW nie widać wyjątków z C++ bo:
a) praktycznie nigdzie nie stosuje się C++ do aplikacji webowych,
b) jak już w C++ coś poleci, to raczej UB i kompletne wywrotka niż
niezłapany wyjątek.
Z Adą myślę, że w punkcie a) jest podobnie, tylko bardziej, w związku z
czym ewentualność punktu b) staje się nieistotna.
Następne wpisy z tego wątku
- 12.02.13 00:23 Andrzej Jarzabek
- 12.02.13 00:36 Andrzej Jarzabek
- 12.02.13 01:15 M.M.
- 12.02.13 02:09 Andrzej Jarzabek
- 12.02.13 08:41 Adam Wysocki
- 12.02.13 10:10 AK
- 12.02.13 10:19 Maciej Sobczak
- 12.02.13 20:14 Andrzej Jarzabek
- 12.02.13 22:28 Andrzej Jarzabek
- 12.02.13 22:42 M.M.
- 12.02.13 23:27 AK
- 12.02.13 23:32 AK
- 13.02.13 00:25 M.M.
- 13.02.13 01:02 Roman W
- 13.02.13 01:03 Roman W
Najnowsze wątki z tej grupy
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 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
Najnowsze wątki
- 2025-01-04 Zbieranie danych przez www
- 2025-01-04 reverse engineering i dodawanie elementów do istniejących zamkniętych produktów- legalne?
- 2025-01-04 w Nowym Roku 2025r
- 2025-01-04 Warszawa => Specjalista ds. IT - II Linia Wsparcia <=
- 2025-01-04 Warszawa => Java Developer <=
- 2025-01-04 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-04 Warszawa => System Architect (Java background) <=
- 2025-01-04 Wrocław => Application Security Engineer <=
- 2025-01-04 Chrzanów => Specjalista ds. public relations <=
- 2025-01-04 Katowice => Key Account Manager (ERP) <=
- 2025-01-03 Problem z odczytem karty CF
- 2025-01-03 Jazda z Warszawy do Krakowa teslą
- 2025-01-03 Wrocław => Konsultant Wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-01-03 Warszawa => International Freight Forwarder <=
- 2025-01-03 Mińsk Mazowiecki => Area Sales Manager OZE <=