eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.misc.elektronikaZagwozdka w C Keil. › Re: Zagwozdka w C Keil - wyjaśnienie.
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!news.unit
    0.net!newsreader4.netcologne.de!news.netcologne.de!peer02.ams1!peer.ams1.xlned.
    com!news.xlned.com!peer02.fr7!futter-mich.highwinds-media.com!news.highwinds-me
    dia.com!newsfeed.neostrada.pl!unt-exc-01.news.neostrada.pl!unt-spo-a-02.news.ne
    ostrada.pl!news.neostrada.pl.POSTED!not-for-mail
    From: "J.F." <j...@p...onet.pl>
    Newsgroups: pl.misc.elektronika
    References: <q3q59d$hp9$1@node1.news.atman.pl> <q3vee4$o74$1@node1.news.atman.pl>
    <5c63f185$0$476$65785112@news.neostrada.pl>
    <q41tof$422$1@node1.news.atman.pl>
    <2...@t...no1>
    In-Reply-To: <2...@t...no1>
    Subject: Re: Zagwozdka w C Keil - wyjaśnienie.
    Date: Thu, 14 Feb 2019 11:42:00 +0100
    MIME-Version: 1.0
    Content-Type: text/plain; format=flowed; charset="iso-8859-2"; reply-type=original
    Content-Transfer-Encoding: 8bit
    X-Priority: 3
    X-MSMail-Priority: Normal
    Importance: Normal
    X-Newsreader: Microsoft Windows Live Mail 16.4.3528.331
    X-MimeOLE: Produced By Microsoft MimeOLE V16.4.3528.331
    Lines: 51
    Message-ID: <5c654649$0$519$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 83.26.122.93
    X-Trace: 1550141001 unt-rea-b-01.news.neostrada.pl 519 83.26.122.93:62283
    X-Complaints-To: a...@n...neostrada.pl
    X-Received-Bytes: 2705
    X-Received-Body-CRC: 1857004120
    Xref: news-archive.icm.edu.pl pl.misc.elektronika:741016
    [ ukryj nagłówki ]

    Użytkownik "Queequeg" napisał w wiadomości grup
    dyskusyjnych:2e88332d-3364-4f9b-b65d-7ecbd98a9931@tr
    ust.no1...
    Irek.N. <t...@j...taki.jest.pl> wrote:
    >>> A swoja droga - czy Keil sam ich nie wylacza ? Dla zmiennych
    >>> volatile
    >>> powinien.
    >
    >> Niestety ale ignoruje zupełnie volatile, a nie powinien moim
    >> zdaniem.

    >Skąd wiesz?
    >Zrób test. Napisz funkcję:
    >int i;
    >void fn(void) { do { } while (i != 42); }
    >Skompiluj z optymalizacją, zobacz kod. Potem dodaj volatile, zobacz
    >kod.

    >Sprawdziłem na raspi (arm), gcc -O2 -S.

    >Bez volatile:
    > ldr r3, .L5
    > ldr r3, [r3] ; tu ładuje zmienną do rejestru
    >.L2:
    > cmp r3, #42 ; tu porównuje rejestr
    > bne .L2 ; tu skacze z powrotem do porównania

    kiepski optymalizator ... czemu porownuje w petli ?

    >Jeszcze ciekawiej się robi, gdy dodasz modyfikator `static`. Bez
    >volatile,
    >arm:
    >.L2:
    > b .L2

    I to jest prawidlowe :-)

    >Dlaczego tak? Bo kompilator wie, że inna jednostka kompilacji nie
    >zmieni
    >wartości tej zmiennej (bo jest statyczna, widoczna tylko w obrębie
    >danej
    >jednostki kompilacji), więc nie ma sensu żadne sprawdzanie, bo
    >zmienna i
    >tak jest zero (bo zmienne globalne są inicjalizowane zerami; spróbuj
    >zamiast 42 wstawić 0 i zobacz, jaki kod wtedy kompilator wygeneruje).

    wstaw 41.

    Albo w jakiejs funkcji wpisz i=40 ...

    J.

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: