Bitwise operators
Representing integers We typically think in terms of decimal (base 10) numbers. Why? A decimal (or base 10) number consists of a sequence of decimal digits (0,1,…,9) = 1x x x x10 0 Least significant digit Most significant digit
Representing integers All numbers within the computer are stored as binary numbers. Why? A binary (or base 2) number consists of a sequence of bits (0,1) =1x2 5 +1x2 4 +0x2 3 +0x2 2 +1x2 1 +1x2 0 Where does the word “bit” come from? Least significant bit Most significant bit
Representing integers Typical integer sizes: unsigned charis 8 bits unsigned shortis 16 bits unsigned intis 32 bits is when stored in an unsigned char is when stored in an unsigned short is when stored in an unsigned int We know that is the same as or
BOOLEAN (LOGICAL) OPERATORS
Boolean (logical) operators &&and ||or !not ^xor (exclusive or)
Boolean (logical) operators &&and F && F is F F && T is F T && F is F T && T is T
Boolean (logical) operators ||or F || F is F F || T is T T || F is T T || T is T
Boolean (logical) operators !not !F is T !T is F
Boolean (logical) operators ^xor F ^ F is F F ^ T is T T ^ F is T T ^ T is F
BITWISE OPERATORS (ON INTEGERS)
Bitwise operators (on integers) &bitwise and |bitwise or ~bitwise not (1’s complement) ^bitwise xor (exclusive or) -negation (2’s complement) Let’s substitute 1 for T and 0 for F.
Bitwise operators (on integers) &bitwise and (really in an 8-bit byte) &001111(really ) (really )
Bitwise operators (on integers) |bitwise or (really in an 8-bit byte) |001111(really ) (really )
Bitwise operators (on integers) ~bitwise not (1’s complement) If x is (really in an 8-bit byte) then ~x is
Bitwise operators (on integers) -negation (2’s complement) algorithm: 1.Perform 1’s complement (~). 2.Add 1. If x is (really in an 8-bit byte) then ~x is x is (after add 1 to previous)
Bitwise operators (on integers) ^bitwise xor (really in an 8-bit byte) ^001111(really ) (really )
Other bitwise operators <<shift bits to the left 1 shift to the left is the same as multiplying by 2. Examples 10 << 1 is 20 7 << 1 is 14 7 << 3 is 56(same as multiplying by 2 3 )
Other bitwise operators >>shift bits to the right 1 shift to the right is the same as integer division by 2. Examples 10 >> 1 is 5 27 >> 3 is 3
More examples unsigned int ui=0; ui = 10 & 7; ui = 10 | 7; ui = 10 ^ 7 unsigned char uc = ~12;
Bits as binary flags. An int is 32 bits so we can number each student in the class from If the bit for a particular student is 1, then that indicates that they took a quiz. First, let’s define the students. #define S0 (1<<0) #define S1 (1<<1) #define S2 (1<<2) #define S3 (1<<3) #define S4 (1<<4) . #define S31 (1<<31)
Bits as binary flags. Now let’s define a quiz. unsigned int quiz1 = 0; How can we indicate that students 0, 5, and 9 took quiz 1?
Bits as binary flags. Now let’s define a quiz. unsigned int quiz1 = 0; How can we indicate that students 0, 5, and 9 took quiz 1? quiz1 = (s0 | s5 | s9);
Bits as binary flags. Now here comes student 12. He takes the quiz on a subsequent day because he was ill. How do we update quiz1 to indicate that student 12 also took the quiz?
Bits as binary flags. Now here comes student 12. He takes the quiz on a subsequent day because he was ill. How do we update quiz1 to indicate that student 12 also took the quiz? quiz1 |= s12;
Bits as binary flags. I’d like to write a message that indicates whether or not student 25 took the exam? How can I do that?
Bits as binary flags. I’d like to write a message that indicates whether or not student 25 took the exam? How can I do that? if ((quiz1&s25)!=0)puts(“taken”); elseputs(“skipped”); if ((quiz1&s25)==s25)puts(“taken”); elseputs(“skipped”); if (quiz1&s25)puts(“taken”); elseputs(“skipped”);
Bits as binary flags. Did both students 22 and 25 take the exam?
Bits as binary flags. Did both students 22 and 25 take the exam? if ((quiz1&(s22|s25)) == (s22|s25) ) puts(“taken”); else puts(“skipped”); if ((quiz1&s22)!=0 && (quiz1&s25)!=0) …
Bits as binary flags. Did everyone except for student 25 take the exam?
Bits as binary flags. Did everyone except for student 25 take the exam? if ( (quiz1&(~s25)) == (~s25) )puts(“yes”); elseputs(“no”);
Bits as binary flags. I thought student 25 took the exam but I was mistaken. How can I rectify my mistake?
Bits as binary flags. I thought student 25 took the exam but I was mistaken. How can I rectify my mistake? quiz1 = quiz1 & (~s25); quiz1 &= ~s25;
Bits as binary flags. Finally, I’d like to print out a list of all of the students that took exam 1.
Bits as binary flags. Finally, I’d like to print out a list of all of the students that took exam 1. int which = 1; for (int i=0; i<32; i++) { ? which <<= 1; }
Bits as binary flags. I’d like to print out a list of all of the students that took exam 1. int which = 1; for (int i=0; i<32; i++) { if (quiz1&which) printf( “student %d took the quiz. \n”, i ); which <<= 1; }
Bits as binary flags. Say I also have quiz1 and quiz2. I’d like a list of all of the students that took quiz1 or quiz2 but not both.
Bits as binary flags. Say I also have quiz1 and quiz2. I’d like a list of all of the students that took either quiz1 or quiz2 but not both. int which = 1; for (int i=0; i<32; i++) { if ( (quiz1&which) ^ (quiz2&which) ) printf( “student %d took either but not both. \n”, i ); which <<= 1; }