-
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: Sat, 09 Feb 2013 17:45:20 +0000
Organization: news.chmurka.net
Lines: 54
Message-ID: <kf61vl$fh0$1@somewhere.invalid>
References: <f...@g...com>
<5...@g...com>
<s...@j...net>
<b...@g...com>
<s...@j...net>
<1...@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>
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 1360431925 15904 90.197.60.254 (9 Feb 2013 17:45:25 GMT)
X-Complaints-To: abuse-news.(at).chmurka.net
NNTP-Posting-Date: Sat, 9 Feb 2013 17:45:25 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130107
Thunderbird/17.0.2
In-Reply-To: <4...@g...com>
X-Authenticated-User: ajarzabek
Xref: news-archive.icm.edu.pl pl.comp.programming:201977
[ ukryj nagłówki ]On 08/02/2013 17:52, M.M. wrote:
> W dniu piątek, 8 lutego 2013 18:14:45 UTC+1 użytkownik Andrzej Jarzabek napisał:
>
>> Wymyślenie zestawu typów i relacji między nimi, odpowiadające
>> problemowi. Przerabianie tego zestawu w miarę jak problem się zmienia.
> Moim zdaniem jest to kwestia szczęścia. Jeśli nie odgadniemy jak
> projekt w przyszłości będzie się rozwijał, to w każdym języku
> dogłębna (nie kłóćmy się o zmianę int na double - to niezauważalnie mały
> nakład pracy) refaktoryzacja staje się koszmarem.
> Przerabianie samochodu albo łodzi na amfibię zawsze jest trudniejszym
> zadaniem niż produkcja amfibii od zera.
Przecież nie mówimy o przerabianiu programu do wyceny instrumentów
fianasowych na program do sterowania samolotem. Można przewidzieć, że
przerabianie programu do wyceny instrumentów finansowych może np.
uwzględnić inne rodzaje instrumentów finansowych i inne metody wyceny
niż oryginalnie przewidywano.
Problem jest taki, że jeśli spróbujesz zaprojektować swoją hierarchię
typów tak, żeby uwzględnić wszelkie możliwe rodzaje instrumentów
finansowych, to wykonasz gigantyczny kawał nikomu nie potrzebnej roboty,
ale też stworzysz gorszy program, bo bardziej skomplikowany, trudniejszy
do zrozumienia, a zatem łatwiej będzie popełnić w nim błąd, i trudniej
go zmienić np. uwględniając instrument finansowy, którego nie
uwzględniłeś w pierwotnym projekcie (bo, powiedzmy, jeszcze nie istniał).
Natomiast jeśli chodzi o przerabianie programu do wyceny instrumentów
tak, żeby wyceniał nowe instrumenty, żeby stosował nowe metody wyceny,
czy żeby cośtam jeszcze robił z tymi instrumentami czy wycenami, czego
pierwotnie nie przewidziałeś, to refaktoryzacja w celu uwzględnienia
danej funkcjonalności nie musi być koszmarem, pod warunkiem, że się
stosuje odpowiednie praktyki.
No i oczywiście może tak być, że ta refaktoryzacja jest dużo prostsza,
przyjemniejsza i mniej podatna na błędy jeśli stosujesz dynamiczny
system typów.
> Znowu muszę zapytać jak zdarta płyta: jaki jest przykład takiej refaktoryzacji
> która będzie trudna w C++, a łatwa w Pythonie, Rubym i reszcie.
PIeczołowice zaprojektowałeś system typów opierając się na założeniu, że
dinozaur to rodzaj gada, a tu nagle się okazuje, że niektóre dinozaury,
które musisz obsłużyć w swoim systemie, w myśl twojego systemu typów
wcale nie są gadami tylko ptakami. W statycznym systemie typów musisz
wszystko teraz przerabiać, przy dynamicznym typowaniu nie przejmujesz
się - jeśli masz funkcję obsługującą dinozaura, to możesz tam wrzucić
dinozaura, niezależnie od tgo, czy jest gadem czy nie.
> Mnie się
> wydaje to bardzo pomocne gdy kompilator C++ krzyczy już w trakcie
> kompilacji że się typy nie zgadzają.
Zwłaszcza jeśli wymaganą logikę możesz zaimplementować w tydzień, a
przez kolejne trzy tygodnie będziesz uciszał krzyki kompilatora.
Następne wpisy z tego wątku
- 09.02.13 19:53 M.M.
- 09.02.13 23:21 Andrzej Jarzabek
- 10.02.13 08:20 firr kenobi
- 10.02.13 11:09 Roman W
- 10.02.13 11:16 Roman W
- 10.02.13 12:12 Maciej Sobczak
- 10.02.13 15:25 Andrzej Jarzabek
- 10.02.13 18:53 Andrzej Jarzabek
- 10.02.13 22:30 M.M.
- 10.02.13 22:36 Maciej Sobczak
- 11.02.13 00:58 Andrzej Jarzabek
- 11.02.13 01:31 Roman W
- 11.02.13 06:04 M.M.
- 11.02.13 09:07 Andrzej Jarzabek
- 11.02.13 10:49 Maciej Sobczak
Najnowsze wątki z tej grupy
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
Najnowsze wątki
- 2025-07-21 cashback
- 2025-07-21 Pomarańczowy rakietnyj on de telefon ;)
- 2025-07-21 Gdańsk => Kotlin Developer <=
- 2025-07-21 Warszawa => Sales Executive / KAM <=
- 2025-07-21 Gdańsk => Programista Kotlin <=
- 2025-07-21 Białystok => Mainframe (z/OS, Assembler) Developer <=
- 2025-07-21 opornosc falowa
- 2025-07-21 Katowice => Key Account Manager IT <=
- 2025-07-21 Wrocław => Controlling systems Consultant <=
- 2025-07-21 Żerniki => Dyspozytor Międzynarodowy <=
- 2025-07-20 Absurdalny zakaz fotografowania będzie nowelizowany
- 2025-07-20 Takie tam...
- 2025-07-20 https://newsgrouper.org/pl.soc.prawo blokuje posty: 154 posts blocked.
- 2025-07-20 Bateria 9V 6F22, alkaliczna v cynkowa, samorozładowanie, bateria wysokiej trwałości do miernika
- 2025-07-20 Tani zakup z ali?