-
Data: 2015-09-26 18:49:45
Temat: Re: Konwersja kodu
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 26.09.2015 17:27, szemrany wrote:
> Hejka,
>
> Widzę, że niektórym się na grupie nudzi i próbują podkarmiać trolla, więc
Przyłączyłbyś się do wspólnego wysiłku a nie tak tylko korzystasz;>
> może wykorzystam ten power w słusznym celu ;-)
> Mianowicie niejaki AK mnie porzucił z pomocą w konwersji kodu z C do
> Pascala i potrzebuję pomocy.
> Już prawie wszystko mam przetłumaczone, ale jeszcze pojawiają się
> wątpliwości. Oto one.
>
> ret->allocated = (size / wordbitsize + 1);
>
> gdzie allocated to int
>
> Czy w C przypisanie wyniku dzielenia konwertuje/obcina go do typu
> całkowitego?
Tak. Bardzo łatwo sprawdziłbyś to w google;>
> Kolejna rzecz.
>
> if (trailing_bits) {}
>
> gdzie trailing_bits to char
> Czy char jest odpowiednikiem typu byte z pascala?
char ma 256 różnych wartośći, ale lepiej użyć unsigned char
albo uint8_t (z <cstdint>)
> Czy takie sprawdzanie warunku to sprawdzenie czy trailing_bits <> 0?
w C i C++ if(x) to to samo co if(x!=0)
> I następna.
>
> x = (word_t) ~0;
> gdzie word_t to uint64
Nie ma czegoś takiego. Jest uint64_t.
> Czy to jest równoważne zapisowi:
>
> x = max_uint64;
Tak. Ale umiesz odpowiedzieć, dlaczego 0, które jest intem ze znakim
promuje się do _szerszego_ inta bez znaku, a dopiero potem jest negowane
bitowo? Jest na to werset w standardzie, czy to zależy od kompilatora?
;-)
Zależnie od kontekstu, pewnie lepiej:
#include <limits>
...
x = numeric_limits<uint64_t>::max();
lub
numeric_limits<decltype(res)>::max(); //wtedy jak zmienisz typ x
wartość też sie zmieni.
> Kolejny niejasny moment:
>
> ret->trailing_bits = *(ret->bitset + ret->allocated - 1) ? (word_t) ~0 : 0;
> Co ta linia przypisuje do trailing_bits?
Ta linia reprezentuje brzydkie hackerstwo;)
> I definicje, żeby było łatwiej:
>
> ret to IntBitSet
>
> typedef unsigned long long int word_t;
>
> typedef struct {
> int size;
> int allocated;
> word_t trailing_bits;
> int tot;
> word_t *bitset;
Nie zjadłeś tu klamerki?
> IntBitSet;
>
> Dziękuję :-)
ret->trailing_bits =
(ret->bitset[ret->allocated - 1] !=0 ) ? (word_t) ~0 : 0;
Teraz jasne? bitset to wskaźnik na dynamicznie zaalokowaną tablicę
(domyślam się z kontekstu), allocated to dligość zaalokowanej tablicy,
ret->bitset + ret->allocated - 1 to wskaźnik na ostatni elemnt tablicy.
* to dereferencja. Więc to to samo co
ret->bitset[ret->allocated - 1]
size,allocated bitset, jeśli robią to co myślę, zalecam wywalić
w cholerę i zastąpić przez vector:) Z drugiej strony jeśli robią
to co myśle, to powinno być +size, nie +allocated;)
Miło by było wrzucić to jako metodę
typedef struct {
int size;
int allocated;
uint64_t trailing_bits;
int tot;
uint64_t *bitset;
void set_trialing_bits() {
trailing_bits=(bitset[allocated - 1]!=0) ?
numeric_limits<uint64_t>::max() : 0;}
} IntBitSet;
Jeśli ostatni element zaalokowanej pamieci (a właśnie, czemu patrzymy
na allocated, nie size?) jest niezerowy, trailbits wypełniamy jedynkami,
w przeciwmy razie zerem.
Uwaga dotycząca ~0 jak poprzednio.
pzdr
bartekltg
Następne wpisy z tego wątku
- 26.09.15 18:57 szemrany
- 26.09.15 19:01 bartekltg
- 26.09.15 19:31 szemrany
- 26.09.15 19:35 bartekltg
- 26.09.15 19:47 M.M.
- 26.09.15 19:56 bartekltg
- 28.09.15 09:57 Tomasz Kaczanowski
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-06-10 wyobrazcie sobie ze
- 2024-06-10 malowanie samochodu
- 2024-06-10 News from Poland
- 2024-06-10 Czy na pewno będą CŁA na chińskie samochody?
- 2024-06-09 Dlaczego w Polsce sie nic nie udaje, na przykładzie niebieskiego lasera a teraz perskowitów
- 2024-06-09 Dlaczego w Polsce sie nic nie udaje, na przykładzie niebieskiego lasera a teraz perskowitów
- 2024-06-09 Wykrywanie przerwy w długim przewodzie zakopanym w ziemi.
- 2024-06-09 Czemu news.chmurka.nwt jest taki wolny?
- 2024-06-11 Funbox 3.0 zakres adresów DHCP
- 2024-06-11 Re: Funbox 3.0 zakres adresów DHCP
- 2024-06-09 Miernik szybkości netu
- 2024-06-11 Panele PV w pionie (prawie).
- 2024-06-11 czy ta grupa żyje?
- 2024-06-11 Warszawa => Senior React Native Developer <=
- 2024-06-11 Gdańsk => Kierownik Działu Spedycji Międzynarodowej <=