eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingPętla FOR (w sam raz na poziom FIR'a)Re: Pętla FOR (w sam raz na poziom FIR'a)
  • Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
    atman.pl!news.chmurka.net!.POSTED!not-for-mail
    From: Paweł Kierski <n...@p...net>
    Newsgroups: pl.comp.programming
    Subject: Re: Pętla FOR (w sam raz na poziom FIR'a)
    Date: Tue, 30 Apr 2013 07:32:43 +0200
    Organization: news.chmurka.net
    Lines: 43
    Message-ID: <klnl20$p27$1@somewhere.invalid>
    References: <517bf604$0$1250$65785112@news.neostrada.pl>
    NNTP-Posting-Host: 195.182.34.201
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: somewhere.invalid 1367299968 25671 195.182.34.201 (30 Apr 2013 05:32:48 GMT)
    X-Complaints-To: abuse-news.(at).chmurka.net
    NNTP-Posting-Date: Tue, 30 Apr 2013 05:32:48 +0000 (UTC)
    User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:17.0) Gecko/20130328 Thunderbird/17.0.5
    In-Reply-To: <517bf604$0$1250$65785112@news.neostrada.pl>
    X-Authenticated-User: pkierski
    Xref: news-archive.icm.edu.pl pl.comp.programming:202989
    [ ukryj nagłówki ]

    W dniu 2013-04-27 18:00, slawek pisze:
    > Takie głupie pytanie - która pętla jest lepsza:
    >
    > 1: for i = 0 to n do call subroutine();
    > 2: for i = n downto 0 call subroutine();
    >
    > Na zdrowy rozum, obie są takie same. Ale chwila - pierwsza rozwija się
    > (przynajmniej w niektórych językach) do
    >
    > cośtam-cośtam-cośtam [zmniejsz rejestr o 1] [porównaj rejestr z
    > wartością n] [podejmij decyzję o kontynuacji]
    >
    > natomiast druga do
    >
    > cośtam-cośtam-cośtam [zmniejsz rejestr o 1] [podejmij decyzję o
    > kontynuacji]
    >
    > gdyż znakomita większość CPU nie potrzebuje porównania z zerem po
    > dekrementacji (ZF się ustawia sama).
    >
    > Czyli druga postać pętli działa o JEDNĄ INSTRUKCJĘ CPU NA PĘTLĘ SZYBCIEJ
    > - *WOW*
    >
    > A teraz bez kłamania - kto tak robi? Wszędzie jak pamiętam pętle są
    > robione "w górę" nawet jak mogą być "w dół", np. przy przeglądaniu po
    > kolei wszystkich kontrolek itp.
    [...]

    Nie robię, bo czas czytania kodu przez programistę jest (zwykle) dużo
    większy (i droższy) niż czas procesora.

    Po za tym - koledzy już zbadali, jak wygląda optymalizacja kompilatorów
    praktyce. Ja tylko dorzucę, że swego czasu walczyłem z kompilatorem,
    żeby *nie* używał memset() - szczególny przypadek, gdy .dll nie mógł
    zależeć od run-time'u C. Zrobiłem pętlę zerującą bufor... i linker
    (Visuala) powiedział, że nie wie, gdzie jest memset(), bo kompilator
    jej użył, rozpoznając pętlę. Zamazywanie wstecz też nie pomogło. Dopiero
    dwie pętle, które fake'owo zapisywały indeks do kolejnych komórek
    o odejmowały go pomogły.

    --
    Paweł Kierski
    n...@p...net

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: