-
Data: 2019-02-10 23:41:57
Temat: Re: Zagwozdka w C Keil.
Od: Mateusz Viste <m...@n...pamietam> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On Sun, 10 Feb 2019 22:32:33 +0100, Irek.N. wrote:
> Pytanie do znawców C. Czy zapis taki:
>
> volatile unsigned int DEL_STEP;
>
> void DELAY(unsigned int Czas) {
> DEL_STEP = Czas;
> while(DEL_STEP);
> }
>
> może różnić się wykonaniem od zapisu takiego?
>
> void DELAY(unsigned int Czas) {
> unsigned char DEL_MSB,DEL_LSB;
> DEL_STEP = Czas;
> while(1) {
> DEL_LSB = DEL_STEP/0x100;
> DEL_MSB = DEL_STEP^0x100;
> if (DEL_MSB == 0 & DEL_LSB == 0) return;
> }
> }
O "Keil" nigdy nie słyszałem, ale C obiło mi się już o uszy, wrzucę moje
3 grosze, być może jakkolwiek pomocne :)
Pierwszy wariant wydaje się bardzo sensowny. Kompilator zepsuty? A może
typ int nie jest atomiczny, i kompilator sprawdza najpierw jednego nibbla,
i dopiero jeśli ten okaże się zerowy to zajmie się drugim?
Próbowałeś może zastąpić jakimś sig_atomic_t?
Ten drugi przykład to w ogóle lichy jest, bo pętla ma teoretyczne prawo
zostać przerwana za każdym razem kiedy wartość DEL_STEP zostaje zmieniona
z wartości o zerowym MSB do wartości o zerowym LSB (np. 0x0034 -> 0x1200)
- a to dlatego, że los może złośliwie zechcieć wykonać twoje przerwanie
akurat pomiędzy liniami:
DEL_LSB = DEL_STEP/0x100;
DEL_MSB = DEL_STEP^0x100;
Nazewnictwo jest tu nieco pomieszane, bo DEL_LSB będzie faktycznie
zawierał 8 "ważniejszych" bitów, tj. MSB. A DEL_MSB będzie zawierał 8
"mniej ważnych" bitów - z resztą celowość operacji XOR całkiem mi tu
umyka, tym bardziej że operuje na bitach których DEL_MSB i tak nie
zobaczy (bo jest charem). Może zamiast '^' (xor) miałeś na myśli
'%' (mod)? Też byłoby niepotrzebnie, ale byłbym wtedy w stanie zrozumieć
co autor miał na myśli.
Swoją drogą, trochę dziwnie patrzeć na dzielenie w takiej operacji. Jeśli
kompilator mądry, to zoptymalizuje twoje "/ 0x100" do ">> 8", ale jeśli
na to nie wpadnie... to będzie mało ekologicznie.
Mateusz
Następne wpisy z tego wątku
- 10.02.19 23:49 J.F.
- 10.02.19 23:55 J.F.
- 10.02.19 23:59 Grzegorz Niemirowski
- 11.02.19 00:10 Grzegorz Niemirowski
- 11.02.19 00:11 Irek.N.
- 11.02.19 00:14 Irek.N.
- 11.02.19 00:28 Irek.N.
- 11.02.19 09:27 Mateusz Viste
- 11.02.19 09:32 Mateusz Viste
- 11.02.19 09:43 Grzegorz Niemirowski
- 11.02.19 10:02 Grzegorz Niemirowski
- 11.02.19 11:10 Mateusz Viste
- 11.02.19 11:54 Queequeg
- 11.02.19 11:59 Queequeg
- 11.02.19 12:17 J.F.
Najnowsze wątki z tej grupy
- SEP 1 kV E
- Aku LiPo źródło dostaw - ktoś poleci ?
- starość nie radość
- Ataki hakerskie
- Akumulatorki Ni-MH AA i AAA Green Cell
- Dławik CM
- JDG i utylizacja sprzetu
- Identyfikacja układ SO8 w sterowniku migających światełek choinkowych
- DS1813-10 się psuje
- Taki tam szkolny problem...
- LIR2032 a ML2032
- SmartWatch Multimetr bezprzewodowy
- olej psuje?
- Internet w lesie - Starlink
- Opis produktu z Aliexpress
Najnowsze wątki
- 2024-12-12 Warszawa => Administrator Bezpieczeństwa IT <=
- 2024-12-12 Ostrów Wielkopolski => Trener zespołu sprzedaży Call Center <=
- 2024-12-12 Kraków => Key Account Manager <=
- 2024-12-11 SEP 1 kV E
- 2024-12-11 DNS restrictions are on
- 2024-12-11 wielkie bu
- 2024-12-11 Białystok => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-11 Aku LiPo źródło dostaw - ktoś poleci ?
- 2024-12-11 Warszawa => Specjalista Bezpieczeństwa Informacji <=
- 2024-12-11 Wrocław => Application Security Engineer <=
- 2024-12-11 Warszawa => Analyst in the Trade Development department (experience wi
- 2024-12-11 Lublin => Programista Delphi <=
- 2024-12-11 Motodziennik #305 Nowy ELEKTRYK za 350 złotych miesięcznie? Kreatywne kredytowanie problemów
- 2024-12-11 Warszawa => Spedytor Międzynarodowy <=
- 2024-12-11 Katowice => Key Account Manager (ERP) <=