C: co lze očekávat
Ladislav Vaiz
spam na nagano.cz
Pondělí Srpen 29 15:15:45 CEST 2016
Tak teď nevím. Ta hodnota 0x234 je chyba a myslíte 0x223 zmiňovanou dříve?
printf("0x%x\n", 0x123 + ((unsigned char)x) + 1); // 0x223
printf("0x%x\n", 0x123 + ((signed char)x) + 1); // 0x123
Původní otázku "co je správně" tedy máte zodpovězenou. Zkuste proměnnou
přetypovat.
L.
Miroslav Draxal napsal(a):
> Teď to chápu. Ale stejně je někde zakopaný pes. Jsem to napsal teď do Michrochipu. Mel jsem dlouho odladěnou knihovnu pro obsluhu SPI. Linkuji ji do mnoha projektů. Aniž bych cokoli řešil, tak se odesílaný buffer ukládal v oblasti 0x00 ~ 0xff. A tam to prostě přeteče a výsledek je, při přetečení ukazuje vždy v rozsahu 0x00 ~ 0xff. Teď jsem do jednoho projektu, který chodí asi 3 roky bez chyb dodělával takovou blbost, a najednou to nechodilo. A tak jsem 3 dny hledal chybu všude možně, jenom ne v té odladěné knihovně SPI. Pak už jsem to celé honil v ASM. A tam jsem našel, že si tentokrát buffer pro SPI uložil na adresu 0x123 a tam to pak přeteklo na tu 0x234. Takže bych očekával, že stejný kód bude produkovat stejně přeložený ASM ať si to proměnné uloží kamkoli.
>
> Ten char je unsigned.
>
> -----Original Message-----
> From: Hw-list [mailto:hw-list-bounces na list.hw.cz] On Behalf Of Ladislav Vaiz
> Sent: Monday, August 29, 2016 1:28 PM
> To: HW-news
> Subject: Re: C: co lze očekávat
>
> Pozor, v článku se řeší pointer, zde jen char.
> Je ten char signed nebo unsigned? Podle toho se liší výsledek výrazu x + 1.
> 1 je int, takže se x převede na int a sečte s 1.
>
>
> #include <stdio.h>
> int main(){
>
> char x = 0;
> x--;
>
> printf("%d\n", ((unsigned char)x) + 1); // 256
> printf("%d\n", ((signed char)x) + 1); // 0
>
> return 0;
> }
>
> L.
>
>
> Jindroush napsal(a):
>
>> Proste ukazovat pointerem mimo objekt a pak nad nim delat aritmetiku
>> je nedefinovane chovani. Reseni neni rozcilovani, ale uprava kodu tak,
>> aby dochazelo jen k definovanemu chovani.
>> J.
>>
>> On 29.8.2016 12:53, Miroslav Draxal wrote:
>>
>>> Je to hodně zjednodušené, to x se používá v programu. Nějak nerozumím
>>> tomu, že si kompilátátor může dělat co chce. Je to char, obsahuje
>>> hodnotu 0xff, po odečtení musí přetéct do nuly.
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>> *From:* Hw-list [mailto:hw-list-bounces na list.hw.cz] *On Behalf Of
>>> *Jindroush
>>> *Sent:* Monday, August 29, 2016 12:35 PM
>>> *To:* HW-news
>>> *Subject:* Re: C: co lze očekávat
>>>
>>>
>>>
>>> Asi prijdu s Wekem po funuse, ale obecne je to x-- undefined
>>> behaviour a kompilator muze delat, co chce ;-)
>>>
>>> http://stackoverflow.com/questions/18186987/decrementing-a-pointer-ou
>>> t-of-bounds-incrementing-it-into-bounds
>>> i s odkazy na c99
>>>
>>> On 29.8.2016 12:22, Miroslav Draxal wrote:
>>>
>>> Dobrý den,
>>>
>>> Minulý týden jsem zde dával report o pnou předpokládané chybě c
>>> XC8. Nějak v tom tápe i Michrochip. Mám dojem, že na tam mají
>>> zaměstnaného studenta, který filtruje zprávy. Jednou píše že je
>>> to OK, jednou že je to chyba. Co na to zdejší odborníci na C. O
>>> co jde.
>>>
>>>
>>>
>>> Mějme následující kód.
>>>
>>>
>>>
>>> char arrayA[3]@0x123;
>>>
>>> char x;
>>>
>>> x = 0;
>>>
>>>
>>>
>>> x--; // x=0xff
>>>
>>> if ( arrayA[x + 1]) {……..}
>>>
>>>
>>>
>>> z jaké adresy má brát if prvek z pole array? Jedná se mi o ten
>>> konstrukt x+1. X je char, čili přeteče na 0x00. Má ukazovat na
>>> 0x123 nebo má brát konstrukt arrayA[x + 1]) přetečení a ukazovat
>>> na 0x223?
>>>
>>>
>>>
>>> U XC8 to teď to je tak, že pokud je array uloženo na 0x023 tak
>>> toto ukazuje na adresu 0x023 a pokud je array uloženo na 0x123
>>> tak to ukazuje na adresu 0x223.
>>>
>>>
>>>
>>> Jak to tedy je?
>>>
>>>
>>>
>>> --
>>> Jindroush <jindroush na seznam.cz> <mailto:jindroush na seznam.cz>
>>>
>>>
>>> _______________________________________________
>>> HW-list mailing list - sponsored by www.HW.cz Hw-list na list.hw.cz
>>> http://list.hw.cz/mailman/listinfo/hw-list
>>>
>>>
>>
>> --
>> Jindroush <jindroush na seznam.cz>
>> ------------------------------------------------------------------------
>>
>> _______________________________________________
>> HW-list mailing list - sponsored by www.HW.cz
>> Hw-list na list.hw.cz
>> http://list.hw.cz/mailman/listinfo/hw-list
>>
>>
>
>
> _______________________________________________
> HW-list mailing list - sponsored by www.HW.cz
> Hw-list na list.hw.cz
> http://list.hw.cz/mailman/listinfo/hw-list
>
> _______________________________________________
> HW-list mailing list - sponsored by www.HW.cz
> Hw-list na list.hw.cz
> http://list.hw.cz/mailman/listinfo/hw-list
>
Další informace o konferenci Hw-list