-
Path: news-archive.icm.edu.pl!newsfeed.gazeta.pl!wsisiz.edu.pl!newsfeed.neostrada.pl!
nemesis.news.neostrada.pl!atlantis.news.neostrada.pl!news.neostrada.pl!not-for-
mail
From: "Filip Sielimowicz" <s...@t...tez.wp.pl>
Newsgroups: pl.comp.programming
Subject: Re: jak optymalizować ze względu na znany warunek w wielokrotnie
powtarzanym bloku? [2]
Date: Mon, 7 Sep 2009 11:13:55 +0200
Organization: TP - http://www.tp.pl/
Lines: 51
Message-ID: <h82j0t$c9b$1@atlantis.news.neostrada.pl>
References: <h7jeoq$1n93$1@news.ett.com.ua> <h7jet7$1n93$2@news.ett.com.ua>
NNTP-Posting-Host: efp194.internetdsl.tpnet.pl
Mime-Version: 1.0
Content-Type: text/plain; format=flowed; charset="UTF-8"; reply-type=original
Content-Transfer-Encoding: 8bit
X-Trace: atlantis.news.neostrada.pl 1252314975 12587 83.14.249.194 (7 Sep 2009
09:16:15 GMT)
X-Complaints-To: u...@n...neostrada.pl
NNTP-Posting-Date: Mon, 7 Sep 2009 09:16:15 +0000 (UTC)
X-Priority: 3
X-MSMail-Priority: Normal
X-Newsreader: Microsoft Outlook Express 6.00.2900.5843
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.5579
Xref: news-archive.icm.edu.pl pl.comp.programming:183412
[ ukryj nagłówki ]
Użytkownik "gupi man'a'go" <2...@i...sk> napisał w wiadomości
news:h7jet7$1n93$2@news.ett.com.ua...
> jak zapisać następujacy program tak, by ładny zapis składniowy nie
> kosztował nieoptymalnie długiego czasu wykonywania?
A jakiego rzędu wielkości jest ta 'nieoptymalność' ? Walka o tego if'a z
warunkeim na prostej zmiennej
typu bool jest imho bez sensu, jeśli, jak mówisz, otacza on 'dowolne bardzo
zagłebione struktury wykonawcze'.
Ja bym się bardziej skupił na tym, by kod był przejrzysty i jak najmniej
redundancji.
A jeśli akurat zagłębiona pętla jest wyjątkowo 'ciasna' i walczymy o każy
takt
(znaczy się bardzo często wykonywana i prosta - proc_1 i proc_3 są bardzo
proste a iterator _2 bardzo liczny),
to rozważyłbym ewentualnie wyłączenie tego warunku 'pętlę wyżej', czyli:
Być może warto wtedy dodatkowo rozważyć zamiany iteratorów, jeśli iterator_1
jest liczniejszy niż iterator_2
(i zamiana jest możliwa)
int condition;
for( iterator_1 )
if( condition )
for( iterator_2 ) {
proc_1();
proc_2();
proc_3();
} else
for( iterator_2 ) {
proc_1();
proc_3();
}
Jest to jakiś kompromis między redundancją całości a nieoptymalnością.
Ale jeszcze raz: jeśli umieszczenie ifa wewnątrz ciasnej pętli powoduje
spadek wydajnosci rzędu 1-5% to IMHO rozważanie tej kwesti
nie ma uzasadnienia praktycznego. A z tego co piszesz o 'złożoności
struktur',
to będzie to jeszcze mniej.
No i jak ktoś wspomniał - kompilator i tak
sam często będzie potrafił 'wyprowadzić' zależną od lokalnej 'stałej'
(zmiennej
nie zmieniającej się) na zewnątrz pętli.
Prawdę mówiąc myślałem, że chodzi Ci o problem, gdzie condition nie jest
zmienną
ale funkcją, której wynik może sięzmienić albo zmienną współdzieloną przy
dostępie wielowątkowym. Ale widzę, że tu sprawa jest maksymalnie prosta.
Ty nie masz większych problemów programistycznych ? :)
Następne wpisy z tego wątku
- 07.09.09 19:46 gupi man'a'go
- 08.09.09 08:00 Filip Sielimowicz
- 08.09.09 09:02 Stachu 'Dozzie' K.
- 08.09.09 14:26 gupi man'a'go
- 08.09.09 14:53 gupi man'a'go
- 09.09.09 09:21 Filip Sielimowicz
Najnowsze wątki z tej grupy
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- 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ą."
Najnowsze wątki
- 2025-08-06 Gdynia => Konsultant wdrożeniowy (systemy controlingowe) <=
- 2025-08-06 Białystok => Inżynier oprogramowania .Net <=
- 2025-08-06 "[...] sejmowe wystąpienie posłanki Klaudii Jachiry, która zakończyła je słowami ,,Sława Ukrainie"."
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Panuje się 181 159,42 zł./mies. na posła w 2026r.
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Czy cos fi przechodzi przez trafo separujące?
- 2025-08-05 kajaki i promile
- 2025-08-05 Re: Tesla jest bezpieczna, wczoraj spaliła się doszczętnie na Ursynowie i nikomu się nic nie stało
- 2025-08-05 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=
- 2025-08-05 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-05 B2B i książka przychodów i rozchodów
- 2025-08-04 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML