Az előadás letöltése folymat van. Kérjük, várjon

Az előadás letöltése folymat van. Kérjük, várjon

2009 Bevezetés a programozásba Krankovits Melinda.

Hasonló előadás


Az előadások a következő témára: "2009 Bevezetés a programozásba Krankovits Melinda."— Előadás másolata:

1 2009 Bevezetés a programozásba Krankovits Melinda

2 Széchenyi István Egyetem 2 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven Legmagasabb prioritási szinten az egyoperandusos, jobbról balra kötő egyes komplemens operátor (~) van, melynek definíciója: ~ előtag-kifejezés Az operátor előbb végrehajtja az egész–előléptetést, ha szükséges. Az eredmény típusa az operandus konverzió utáni típusa. Az eredmény maga a bit szintű egyes komplemens, azaz ahol az operandus bit 1 volt, ott az eredmény bit 0 lesz, és ahol az operandus bit 0 volt, ott az eredmény bit 1 lesz. Feltéve, hogy az egész–előléptetés 16 bites, és hogy: unsigned short x = 0XF872, /* 1111100001110010 */ maszk = 0XF0F0;/* 1111000011110000 */, akkor a ~x 0000011110001101 2, és a ~maszk 0000111100001111 2. A bit szintű operátorok csak signed és unsigned egész típusú adatokra: char, short, int és long használhatók.

3 Széchenyi István Egyetem 3 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven A balról jobbra csoportosító eltolás operátorok ( >) prioritása alacsonyabb az aritmetikai műveletekénél, de magasabb, mint a reláció operátoroké. Az eltolás operátorok első operandusuk értékét balra (<<) vagy jobbra (>>) tolják annyi bitpozícióval, mint amennyit a második operandus meghatároz. A K1<<K2 balra tolja K1 értékét K2 bitpozícióval úgy, hogy jobbról 0 bitek jönnek be. A K1>>K2 művelet K1 értékét K2 bitpozícióval tolja jobbra. Ha K1 valamilyen unsigned típusú, akkor balról 0 bitek jönnek be. Ha K1 signed, akkor az operátor az előjel bitet sokszorozza. unsigned, nem negatív K1 esetén a jobbra tolás K1/2K2 hányados egész részeként is interpretálható. Miután a C–ben nincs egész alul vagy túlcsordulás, a > műveletek értékvesztést is okozhatnak, ha az eltolt eredmény nem fér el az első operandus konvertált típusában.

4 Széchenyi István Egyetem 4 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven unsigned short x = 0XF872, /* 1111100001110010 */ maszk = 0XF0F0;/* 1111000011110000 */, akkor a ~x 0000011110001101 2, és a ~maszk 0000111100001111 2., akkor x >5 0000011110000111 2 Eltolás példa:

5 Széchenyi István Egyetem 5 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven A művelet bitről-bitre valósul meg az operandusok értékén, s egy bitre vonatkoztatva az eredmény így néz ki: A bit szintű logikai operátorok prioritásuk csökkenő sorrendjében az és (&), a kizáró vagy (^), valamint a vagy (|). A többi műveletre való tekintettel prioritásuk magasabb a kétoperandusos logikai operátorokénál, de alacsonyabb a relációkénál.

6 Széchenyi István Egyetem 6 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven Példa bitszintű logikai operátorokra: unsigned short x = 0XF872, /* 1111100001110010 */ maszk = 0XF0F0;/* 1111000011110000 */, akkor a ~x 0000011110001101 2, és a ~maszk 0000111100001111 2., akkor x >5 0000011110000111 2, az x|maszk értéke 1111100011110010 2. Állíthatjuk, hogy az eredményben minden olyan bit egy, ami a maszk–ban az volt. Az x^x eredménye biztosan tiszta zérus., az x&~maszk értéke 0000100000000010 2.

7 Széchenyi István Egyetem 7 Bit szintű operátorok ( ~, >, &, ^ és |) Műveletek és kifejezések Programozás C nyelven Összetett példa: binaris.c … num=0; while ( (c=getchar()) !=EOF ) { if ( c!='\n' && c>='0' && c<='9' ) {/* ASCII - bin ris konverzi˘ */ num = num*10 + c - '0'; } else {/* a sz m v‚ge */ printf("%u sz m bin risan : ", num); for (i=16; i>0; i--) { bit = num >> 15 ; /* a vezet‹ bit a v‚g‚re kerl */ bit = bit + '0' ; /* a 0 vagy 1 ir sjel el‹ llˇt sa */ putchar(bit); num = num << 1; /* a k”vetkez‹ bit a vezet‹ helyre kerl */ } putchar('\n'); printf("\nG‚pelj be egy pozitˇv sz mot (1.. 65535) : "); num = 0; fflush(stdin); }

8 Széchenyi István Egyetem 8 Hozzárendelés operátorok = *= /= %= += -= &= ^= |= >= Műveletek és kifejezések Programozás C nyelven Van tehát egyszerű hozzárendelés operátor (=) és vannak összetettek vagy kombináltak (ezek a többiek). A K1 = K2 kifejezésben K1-nek módosítható balértéknek kell lennie. (megjegyzés: jobbérték fogalma!) A definíció megengedi a hozzárendelés operátor K1 = K2 = K3 =... = Kn = kifejezés formájú használatát is, amikor is a kifejezés kiértékelése után jobbról balra haladva az operandusok felveszik a kifejezés értékét. Az egész konstrukció értéke most is a kifejezés értéke lesz.

9 Széchenyi István Egyetem 9 Hozzárendelés operátorok = *= /= %= += -= &= ^= |= >= Műveletek és kifejezések Programozás C nyelven Kombinált operátorok: … for(ft=ALSO; ft<=FELSO; ft=ft+LEPES) /*Most így írható*/ for(ft=ALSO; ft<=FELSO; ft+=LEPES) Megjegyzés: A += és –= bal oldali operandusa mutató is lehet, amikor is a jobb oldali operandus köteles egész típusú lenni.


Letölteni ppt "2009 Bevezetés a programozásba Krankovits Melinda."

Hasonló előadás


Google Hirdetések