-
Path: news-archive.icm.edu.pl!news.gazeta.pl!newsfeed.pionier.net.pl!news.glorb.com!n
ews-in-01.newsfeed.easynews.com!easynews!core-easynews-01!easynews.com!en-nntp-
08.dc1.easynews.com.POSTED!not-for-mail
From: A.L. <a...@a...com>
Newsgroups: pl.comp.programming
Subject: Re: jak napisać szybki program
Message-ID: <u...@4...com>
References: <9...@r...googlegroups.com>
X-Newsreader: Forte Agent 4.2/32.1118
MIME-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: 8bit
Lines: 52
X-Complaints-To: a...@e...com
Organization: Forte Inc. http://www.forteinc.com/apn/
X-Complaints-Info: Please be sure to forward a copy of ALL headers otherwise we will
be unable to process your complaint properly.
Date: Sun, 17 May 2009 09:11:17 -0500
Xref: news-archive.icm.edu.pl pl.comp.programming:181930
[ ukryj nagłówki ]On Sun, 17 May 2009 02:31:27 -0700 (PDT), Marteno Rodia
<m...@o...pl> wrote:
>Góglałem, ale nie udało mi się znaleźć syntetycznej odpowiedzi na
>pytanie. Interesuje mnie, jak należy pisać program, żeby wykonywał się
>on szybko. Z reguły pisuję w Javie, teraz mam napisać program (a
>właściwie część do większego programu) w C++, który wykonuje pewne
>obliczenia potrzebne do kompresji wideo. Będzie dużo danych i dużo
>liczenia.
>
>Ogólnie wiem, że:
>
>1) dużo czasu zjadają np. operacje wejścia/wyjścia
>2) w miarę możliwości warto przydzielać pamięć statycznie, a nie
>dynamicznie
>3) unikać nadmiaru rzeczy wykonywanych w pętli (np. sprawdzanie
>jakichś warunków) - innymi słowy:
>4) tak przebudować algorytm, żeby zrobić to samo wykonując mniejszą
>ilość operacji.
>
>Pytania:
>1) Czy mam rację?
>2) Co jeszcze o czym nie wiem?
Nei wiesz o Zadadach Kernighana:
1. "Make it working frst, make it nice later". Najpierw program musi
dzialac, a POTEM musi dzialac szybko. Optymalizacja w trakcie pisania
programu da architektoniczny potworek, na ogol i tak daleki od
optymalnosci. Oczywiscie, nie nalezy uzywac rozwiazan o ktorych od
razu wiadomo ze sa neidobre, na przykald liczenei w kolko tego samego
wyrazenia w petli, czy stosowanei niewlasciwych struktur danych
2. "20% kodu pochlamie 80% casu wykonywania programu". Tzreba te 20%
znalezc i zoptymalizowac. Oczywiscie, po zoptymalizowaniu, INNE 20%
czasu bedzie pochlanialo 80%, wiec procedura musi byc stosowana
iteracyjnie
3. Stosowac nalezy odpowiednei struktury danych zapewniajace
odpowienia zlozonosc obliczeniowa stosowna do skali problemu. Lista
jest bardzo pomocna struktura, ale wyszukwianei w liscie jest liniowe
i kosztowne. Wiec jak lisyta jest dluga a wyszukwianie czeste, to
uzywanei listy bedzie powodowalo starte czasu.
Lista to tylko przyklad. Ilu programistow w Javie uzywajacych HashMap
wie co to jest "loading factor" i dlaczego HasnMap ma konstruktor
pozwalajacy zdefiniowac ow "loading factor"?...
Dla programistow w Jave polecam ksiazke "Java Performance Tuning",
Jack Shirazi, O'Reilly, 2000
A.L.
Następne wpisy z tego wątku
- 17.05.09 16:21 Bronek Kozicki
- 17.05.09 17:18 A.L.
- 17.05.09 18:53 Marteno Rodia
- 17.05.09 19:13 A.L.
- 17.05.09 19:21 jelen
- 17.05.09 19:53 A.L.
- 17.05.09 19:55 A.L.
- 17.05.09 20:27 Jacek Czerwinski
- 17.05.09 20:31 Wojtek Pietruszewski
- 17.05.09 20:35 A.L.
- 17.05.09 20:52 Bronek Kozicki
- 17.05.09 20:53 Bronek Kozicki
- 17.05.09 20:59 A.L.
- 17.05.09 21:00 A.L.
- 17.05.09 21:01 A.L.
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- 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
Najnowsze wątki
- 2025-01-12 USB3.x->HDMI/DP ze sterownikami w win11
- 2025-01-12 Jak na naszych oczach odradza się cenzura :-)
- 2025-01-11 Koszty prowadzenia firmy za granicą
- 2025-01-11 19 migrantów
- 2025-01-11 300km/h
- 2025-01-11 Kongres USA uchwalił "Prawo babci Pawlakowej" na MTK [Lex Gradma Pawlak]
- 2025-01-11 Riga => Specjalista ds. public relations <=
- 2025-01-11 Przestępca wyborczy Musk nadciąga nad Tuskistan?
- 2025-01-11 Białystok => Delphi Programmer <=
- 2025-01-09 Jaka nawigacja z asystentem zmiany pasa ruchu?
- 2025-01-10 Coś dusi.
- 2025-01-09 akumulator napięcie 12.0v
- 2025-01-10 Białystok => Architekt rozwiązań (doświadczenie w obszarze Java, A
- 2025-01-10 Warszawa => Software .Net Developer <=
- 2025-01-10 Białystok => Application Security Engineer <=