-
Path: news-archive.icm.edu.pl!newsfeed.gazeta.pl!news.onet.pl!not-for-mail
From: Jacek Czerwinski <...@...z.pl>
Newsgroups: pl.comp.programming
Subject: Re: jak napisać szybki program
Date: Thu, 21 May 2009 23:04:58 +0200
Organization: http://onet.pl
Lines: 101
Message-ID: <gv4fm2$cfc$1@news.onet.pl>
References: <9...@r...googlegroups.com>
<guooce$u1t$1@news.onet.pl> <gup1i8$rlj$1@mx1.internetia.pl>
<gurkis$5d7$1@news.onet.pl> <gurld3$7gl$1@news.onet.pl>
<gv2hk9$77r$1@inews.gazeta.pl>
<4...@g...googlegroups.com>
<gv3u8g$f6g$1@inews.gazeta.pl>
<3...@s...googlegroups.com>
<gv4d3a$r0n$1@inews.gazeta.pl>
NNTP-Posting-Host: 77-254-198-223.adsl.inetia.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: news.onet.pl 1242939906 12780 77.254.198.223 (21 May 2009 21:05:06 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Thu, 21 May 2009 21:05:06 +0000 (UTC)
User-Agent: Thunderbird 2.0.0.21 (Windows/20090302)
In-Reply-To: <gv4d3a$r0n$1@inews.gazeta.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:182100
[ ukryj nagłówki ]Mariusz Marszałkowski pisze:
> Marcin 'Malcom' Malich <m...@g...com> napisał(a):
>
>> On 21 Maj, 18:07, "Mariusz Marsza=B3kowski"
>> <b...@W...gazeta.pl> wrote:
> Po prostu jest mniej pracy w C. Zmienne typu strukturalnego w C (zgodnie z
> ideą C) deklaruje się globalnie, wszystkie funkcje deklaruje się
> globalnie, a dostęp do wszystkich danych i składowych jest publiczny.
Jeśli chciałeś podać przykład za C (za tym stylem) to ci nie wyszło.
Brak podziału na prywatny/publiczny (w dowolny paradygmacie, czy to
stary modularnym, czy obiektowym) odbiera ci swobodę (w pr. małym) lub
blokuje *w wielkim projekcie) możliwość ulepszenia lokalnej
implementacji bez zmiany interfejsu.
Zostaje żmudna ręczna robota.
Wracając do optymalizacji, znasz takie słowo "gówna lepiej nie ruszać" -
to m.in. o programowaniu w całości na globalach. Ulepszanie zwykle nie
następuje.
ścinam się czasem z gośćmi którym się wydaje, że reprezentują
proceduralny styl pisania. Z tym że nie wiedzą, co to naprawdę jest, że
też zawiera podział na publiczne i prywatne. Trzeba by sie odwołać do
książek z lat 70-tych i sobie powtórzyć.
> W C++ projektując strukturę danych trzeba dodatkowo zastanowić się:
> 1) jakie metody będą miały dostęp do jakich danych
> 2) jakie składowe będą w sekcjach prywatnych, jakie w chronionych
> 3) jakiej hierarchii dziedziczenia użyć
> Po zmianie struktury danych w C++ trzeba te kroki przejść na nowo. Te
> kroki ułatwiają ponowne wykorzystanie kodu, zmniejszają podatność na
> błędy, ale nie ułatwiają optymalizacji zapisu.
>
>
> Natomiast w C masz w całym programie dostęp do wszystkich danych. Od razu
> podczas wczytywania zrobisz wstępne obliczenia i zmodyfikujesz globalne
> dane. Po prostu w C trzeba zmodyfikować mniej kodu.
Lub cały kod - patrz wyżej.
>
> Jeśli w końcu dokonasz kilku takich spostrzeżeń i kilku takich modyfikacji
> kodu, obojętnie czy pisałeś w C czy w C++, to dojdziesz do wniosku że
> pierwotny podział kodu i danych na logiczne bloki nie był najlepszy. Będzie
> trzeba przepisać wszystko od nowa. I znów zyskasz pisząc w C, bo omijasz
> podział na klasy i nie zastanawiasz się jaką składową umieścić w jakiej
> klasie i w jakiej sekcji, żeby po kolejnym spostrzeżeniu cały ten
> skrupulatny podział trzeba było zburzyć...
>
>>> Obudowywanie danych w klasy (cho=E6by jako sk=B3adowe statyczne, kt=F3re =
>> nie daj=B1
>>> narzutu) podwaja nak=B3ad pracy przy takim eksperymentowaniu. Wi=EAc pows=
>> taje
>>> programowanie w C przy u=BFyciu kompilatora C++ :)
>> Narzutu czego?
>>
>> Nie potrafie zrozumiec do czego zmierzasz :>
>
> Narzut na dodatkowe zaprojektowanie klas. Dobre zaprojektowanie jest
> czasochłonne.
Lepsze jest jakiekolwiek ujęcie np. z hermetyzacją (dorzuć sobie inne
postulaty) niz programowanie na globalsach. Kod z kiepskimi klasami
łatwiej ulepszysz, kod na globalsach tylko w kosz.
Układ klas choćby uwierający ogarniesz i przemyślisz. Układ setek
globalnych (publicznych) zmiennych ... możesz sobie obiecywać że ogarniesz.
> Klasy projektuje się
>
Widzisz, projektuje się. mniejszy będzie nakład pracy na konserwację,
jeśli proces projektowania(choćby niedoskonały) zachodzi (alternatywą
jest zupełny żywioł). A jeśli proces projektowania zachodzi, notacja
obiektowa lepiej wyraża 'co poeta miał na myśli'. Alternatywą jest
modularne 'stare' programowanie, ale tam też PROJEKTUJESZ co jest
prywatne, co publiczne itd.
W innej części tego wątku poparłem cię, że radykalnie mądrzejszy
algorytm da więcej niż kolanowe tricki. Niestety tym razem promujesz
ujecie gdzie trudno o wyższy wysiłek intelektualny (lub mniejszy efekt
porównywalnym wysiłkiem). Jednak tricki niż intelekt.
ujęcie obiektowe nie wzięło się z próżni, jest kolejną iteracją w
kilkudziesięcioletnim procesie rozwoju. Realizuje (na swój sposób)
kanoniczne zasady: podział na interfejs a implementację, hermetyzację,
izolację, abstrakcję i kilka innych słówek (pora już późna). Zwolennicy
OO wierzą/mają dowody, że ten styl lepiej realizuje bardzo stare postulaty.
Broń sobie ujęcia proceduralnego (modularno-proceduralnego) jak chcesz,
ale sorry troszkę głębiej to poznaj. Złap jakaś zżólknietą książke i
poznaj temat.
Małe CV: W 1990 prowadziłem (w zespole) system w C migrowany na C++
(oczywiście przez etap C z klasami, a jeszcze wczesiej był eta
obiektowym w swym sensie jeszcze w notacji w C) na drobne Hmmm set tyś
linii. Ale mogę kurna czegoś nie wiedzieć.
PS. Jest taki podzbiór programowania w CPP (i to spory) gdzie nie ma
mierzalnych narzutów w kodzie maszynowym (ale nie o tym piszę). Myślę że
dorabiasz ideologię do praktyki.
Następne wpisy z tego wątku
- 21.05.09 21:55 Mariusz Marszałkowski
- 23.05.09 21:59 Maciej Sobczak
- 24.05.09 00:06 A.L.
- 28.05.09 19:32 Mariusz Marszałkowski
- 30.05.09 05:15 Mariusz Marszałkowski
- 07.06.09 05:20 Remek
- 07.06.09 14:40 A.L.
- 07.06.09 17:35 Mirosław Habarta
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-19 koniki obsiadły kolejki i numerki
- 2024-12-18 Poseł oszukany "na policjanta"
- 2024-12-18 znów chory psychicznie
- 2024-12-18 Katowice => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2024-12-18 Poznań => Dyspozytor Międzynarodowy <=
- 2024-12-18 Katowice => System Architect (background deweloperski w Java) <=
- 2024-12-18 Gdańsk => System Architect (Java background) <=
- 2024-12-18 Warszawa => Helpdesk Specialist <=
- 2024-12-18 Katowice => Kierownik Działu Zarządzania Platformą Wirtualizacji i
- 2024-12-18 Bieruń => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-18 Żerniki => Employer Branding Specialist <=
- 2024-12-18 Gliwice => Specjalista ds. public relations <=
- 2024-12-18 Kablówka z modułem CAM
- 2024-12-18 Warszawa => Spedytor międzynarodowy <=
- 2024-12-18 Wróblewo => Analityk finansowy <=