-
Data: 2019-02-14 11:42:00
Temat: Re: Zagwozdka w C Keil - wyjaśnienie.
Od: "J.F." <j...@p...onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie 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.
Następne wpisy z tego wątku
- 14.02.19 11:49 Grzegorz Niemirowski
- 14.02.19 11:59 Queequeg
- 14.02.19 12:14 Queequeg
- 14.02.19 13:07 J.F.
- 14.02.19 13:11 J.F.
- 14.02.19 13:15 J.F.
- 14.02.19 13:25 Queequeg
- 14.02.19 13:36 Grzegorz Niemirowski
- 14.02.19 13:52 a...@m...uni.wroc.pl
- 14.02.19 13:59 Queequeg
- 14.02.19 14:01 Grzegorz Niemirowski
- 14.02.19 14:02 Queequeg
- 14.02.19 14:04 Queequeg
- 14.02.19 14:07 Queequeg
- 14.02.19 17:03 J.F.
Najnowsze wątki z tej grupy
- LED
- System operacyjny dla 6800?
- Przyłączenie działki do sieci elektrycznej
- Działalność nierejestrowana/definicja sprzętu elektronicznego/misie i kolejki
- Smukły, długi ściągacz izolacji do kynaru
- rezystor 3 omy 400W
- [newbie] Jaki multimetr za 2-4 stówy?
- szafka sieciowa
- Raspberry Pi 5 + dyski SATA
- lutownica na węgiel
- Znów czary (albo niewiedza) - tym razem fotowoltaika
- Chess
- Vitruvian Man - parts 7-11a
- przeźroczyste koszulki
- Re: Win 10/11 nie lubi OKI
Najnowsze wątki
- 2024-05-20 Fiat 125p wer. pikup - w PRL moszna było, w III Reczy [pospolitej] nie moszna
- 2024-05-19 Pożar salonu z chińskimi elektrykami
- 2024-05-18 LED
- 2024-05-19 ceny nieruchomości
- 2024-05-18 Szczecin => UX/UI Designer <=
- 2024-05-18 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-18 Warszawa => Software .Net Developer <=
- 2024-05-18 Warszawa => Mid/Senior QA Engineer <=
- 2024-05-18 Ulm => Solution Architect (sichere Kommunikation und IoT-Loesungen <=
- 2024-05-18 Katowice => Head of Virtualization Platform Management and Operating S
- 2024-05-18 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-18 Wrocław => Consultant/Implementer Comarch ERP XL <=
- 2024-05-18 Gdańsk => Head of International Freight Forwarding Department <=
- 2024-05-18 Warszawa => Account Manager (Recruitment Services) <=
- 2024-05-18 Łódź => Salesperson - CRM Systems <=