-
Data: 2009-09-07 09:13:55
Temat: Re: jak optymalizować ze względu na znany warunek w wielokrotnie powtarzanym bloku? [2]
Od: "Filip Sielimowicz" <s...@t...tez.wp.pl> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- 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
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-05-26 O co chodzi?
- 2024-05-26 PJ autobus-tramwaj
- 2024-05-26 Renault Trafic i lampka z czerwonym STOP
- 2024-05-26 cena pięciocyfrowa
- 2024-05-26 Re: Jak dobra KE "okrada" złą Rosję "dla Ukrainy"
- 2024-05-25 supercap
- 2024-05-25 Sulzbach => Technischer Rollouter (d/m/w) <=
- 2024-05-25 Warszawa => Senior Account Manager <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Interactive/Experience Designer <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Re: znów ten wrocław