eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingPakowanie strukturRe: Pakowanie struktur
  • X-Received: by 10.140.96.104 with SMTP id j95mr198879qge.9.1449155319360; Thu, 03 Dec
    2015 07:08:39 -0800 (PST)
    X-Received: by 10.140.96.104 with SMTP id j95mr198879qge.9.1449155319360; Thu, 03 Dec
    2015 07:08:39 -0800 (PST)
    Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!news.unit
    0.net!news.glorb.com!mv3no10991573igc.0!news-out.google.com!f23ni2qge.0!nntp.go
    ogle.com!f78no6145605qge.1!postnews.google.com!glegroupsg2000goo.googlegroups.c
    om!not-for-mail
    Newsgroups: pl.comp.programming
    Date: Thu, 3 Dec 2015 07:08:39 -0800 (PST)
    In-Reply-To: <56604c0e$0$679$65785112@news.neostrada.pl>
    Complaints-To: g...@g...com
    Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=159.205.154.116;
    posting-account=xjvq9QoAAAATMPC2X3btlHd_LkaJo_rj
    NNTP-Posting-Host: 159.205.154.116
    References: <n3n4m5$grf$1@node1.news.atman.pl>
    <a...@g...com>
    <5...@g...com>
    <f...@g...com>
    <566030e8$0$22825$65785112@news.neostrada.pl>
    <a...@g...com>
    <566044c6$0$682$65785112@news.neostrada.pl>
    <3...@g...com>
    <56604c0e$0$679$65785112@news.neostrada.pl>
    User-Agent: G2/1.0
    MIME-Version: 1.0
    Message-ID: <6...@g...com>
    Subject: Re: Pakowanie struktur
    From: "M.M." <m...@g...com>
    Injection-Date: Thu, 03 Dec 2015 15:08:39 +0000
    Content-Type: text/plain; charset=ISO-8859-2
    Content-Transfer-Encoding: quoted-printable
    Xref: news-archive.icm.edu.pl pl.comp.programming:208935
    [ ukryj nagłówki ]

    On Thursday, December 3, 2015 at 3:05:24 PM UTC+1, Tomasz Kaczanowski wrote:
    > W dniu 2015-12-03 15:00, M.M. pisze:
    > > On Thursday, December 3, 2015 at 2:34:00 PM UTC+1, Tomasz Kaczanowski wrote:
    > >> W dniu 2015-12-03 14:08, M.M. pisze:
    > >>> On Thursday, December 3, 2015 at 1:09:14 PM UTC+1, Tomasz Kaczanowski wrote:
    > >>>
    > >>>> i gdzieniegdzie będzie mały bum, bo *((int*)(buf+2)); może mieć zdziebko
    > >>>> inną zawartość, niż nam się wydaje,
    > >>>
    > >>> Nie rozumiem. W jakich sytuacjach może mieć inną zawartość? Na moje
    > >>> albo reprezentacja bitowa się zgadza, albo nie. Jeśli nie, to w
    > >>> ogóle nie można używać kopiowania bitów.
    > >>
    > >> Tam gdzie zmienne muszą mieć wyrównane adresy. O ile w przypadku
    > >> spakowanej struktury przy odczycie kompilator wykona za nas odpowiednie
    > >> operacje, to w takim przypadku, gdy rzutujesz dane spod adresu, mówisz
    > >> kompilatorowi "wiem co robię, nie wtrącaj się", a, że wynik może w takim
    > >> przypadku być inny, cóż...
    > >
    > > To przy operacji:
    > > *((int*)(buf+2))
    > > kompilator nie wygeneruje takiego samego kodu jak przy wypakowaniu
    > > inta przesuniętego o 2 bajty w strukturze? Myślałem że na danej
    > > platformie kompilator bezpiecznie przerzuci dane na wyrównany adres i
    > > dopiero potem zacznie operować na tych danych.
    >
    >
    > z doświadczenia wiem, że nie poprawne było dopiero
    >
    > int zmienna;
    > memcpy(zmienna, (buf+2), sizeof(int));


    Jeśli wcześniej było:
    memcpy( buf+2 , &zmienna , sizeof(int) );
    To też nie widzę zagrożenia. Rozmawiamy rzecz jasna o zgodnym formacie
    na poziomie bitów.


    Gdy ktoś upakował dane przy pomocy memcpy, a potem odzyskuje przez:
    *((int*)(buf+2))
    to obawiam się, że nie zawsze zadziała, o ile się nie mylę, to zadziała
    tylko na bigendian.


    Pozdrawiam

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: