-
Data: 2009-05-17 14:11:17
Temat: Re: jak napisać szybki program
Od: A.L. <a...@a...com> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- 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
- C++. Podróż Po Języku - komentarz
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
Najnowsze wątki
- 2025-06-28 Upadłość i zwolnienia [w Diorze, która była pol prod. głośników - przyp. JMJ]
- 2025-06-28 Taśma izolacyjna do prac elektrycznych
- 2025-06-27 Recenzja 3.1A ;) w 6 gniazdach...
- 2025-06-27 Re: Recenzja 3.1A ;) w 6 gniazdach...
- 2025-06-27 Re: Recenzja 3.1A ;) w 6 gniazdach...
- 2025-06-27 Re: Recenzja 3.1A ;) w 6 gniazdach...
- 2025-06-28 China => Production Coordinator / Representant Product Dev <=
- 2025-06-28 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=
- 2025-06-28 Piaseczno => Developer .NET <=
- 2025-06-28 Warszawa => Specjalista ds. Sprzętu Komputerowego <=
- 2025-06-28 Warszawa => Recruiter 360 <=
- 2025-06-28 Warszawa => Sales Assistant <=
- 2025-06-28 Warszawa => PC Hardware Expert / Specjalista PC <=
- 2025-06-27 Warszawa => Fullstack PHP Developer <=
- 2025-06-27 Gdańsk => Programista Delphi <=