-
Data: 2015-12-03 13:09:14
Temat: Re: Pakowanie struktur
Od: Tomasz Kaczanowski <kaczus@dowyciecia_poczta.onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2015-12-03 12:55, M.M. pisze:
> On Thursday, December 3, 2015 at 10:59:27 AM UTC+1, Adam Klobukowski wrote:
>> W dniu środa, 2 grudnia 2015 18:21:16 UTC+1 użytkownik M.M. napisał:
>>> On Wednesday, December 2, 2015 at 5:02:15 PM UTC+1, Borneq wrote:
>>>> Jest jeszcze ilość bitów po dwukropku jak :8, :16 czy :32 - kiedy się
>>>> stosuje?
>>> Generalnie wtedy kiedy chcemy oszczędzać pamięć i przechowywać specyficzne
>>> wartości, np. trzy liczby, każda zajmująca max 10 bitów. Bez tej sztuczki
>>> potrzeba trzech typów 16-bitowych, czyli razem 48 bitów. Z tą sztuczką 30
>>> bitów, które kompilator wyrówna do 32 - mamy oszczędność 16 bitów.
>>> Pozdrawiam
>>
>> Nie tylko. To trzeba też robic przy dekodowaniu danych idących strumieniem.
Przykładowo: mamy system który ma domyslnie 4 bajty na inta i tak rozpisuje struktury
(pole short int w strukturze i tak bedzie mialo 4 bajty). Teraz, jeśli w takim
systemie przymiemey strumien danych, gdzie short int jest spakowany na 2 bajty, to po
zapisaniu takiego strumienia nie możemy go wprost intepretować 'normalna' strukturą,
ale własnie takie taką spakowaną, lub stosować ine sztuczki. Tego typu problemy
wystepują np. w implementacjach protokołów sieciowych.
>
> Jeśli dekodowanie chcemy zrobić przy pomocy memcpy lub przy pomocy
> rzutowania wskaźników to owszem. Ale dekodowanie można też zrobić
> do nieupakowanej struktury:
>
> // przepraszam za metakod
> char buf[2*6] = read();
> struct X {
> short a;
> int b;
> };
>
> X x[2];
> x[0].a = *((short*)(buf+0));
> x[0].b = *((int*)(buf+2));
> x[1].a = *((short*)(buf+6));
> x[1].b = *((int*)(buf+8));
>
> Pozdrawiam
i gdzieniegdzie będzie mały bum, bo *((int*)(buf+2)); może mieć zdziebko
inną zawartość, niż nam się wydaje, ale co do tego, że dekodować można
nie zwracając uwagi na upakowanie to fakt...
--
Kaczus
http://kaczus.ppa.pl
Następne wpisy z tego wątku
- 03.12.15 14:08 M.M.
- 03.12.15 14:33 Tomasz Kaczanowski
- 03.12.15 15:00 M.M.
- 03.12.15 15:05 Tomasz Kaczanowski
- 03.12.15 15:20 Maciej Sobczak
- 03.12.15 16:08 M.M.
- 03.12.15 16:19 M.M.
- 03.12.15 16:21 witek
- 03.12.15 16:23 M.M.
- 03.12.15 17:29 Maciej Sobczak
- 03.12.15 17:45 witek
- 03.12.15 17:56 M.M.
- 03.12.15 18:02 M.M.
- 03.12.15 18:15 M.M.
- 03.12.15 18:37 witek
Najnowsze wątki z tej grupy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- 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??
Najnowsze wątki
- 2025-02-19 Lista afer
- 2025-02-19 Lista afer
- 2025-02-19 Lista afer PIS
- 2025-02-19 Ogrodzenie dla krów szkockich "Highland"
- 2025-02-19 Gdańsk => System Architect (background deweloperski w Java) <=
- 2025-02-19 Gdańsk => Solution Architect (Java background) <=
- 2025-02-19 Białystok => Data Engineer (Tech Leader) <=
- 2025-02-19 Kraków => Ekspert IT (obszar systemów sieciowych) <=
- 2025-02-19 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-02-19 Rzeszów => International Freight Forwarder <=
- 2025-02-19 Poznań => Konsultant wdrożeniowy Comarch XL/Optima (Księgowość i
- 2025-02-19 Chrzanów => Spedytor Międzynarodowy (handel ładunkami/prowadzenie f
- 2025-02-19 Bieruń => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-02-19 Nigdy
- 2025-02-19 Katowice => Key Account Manager (ERP) <=