Programmazione D - Operatori bit per bit

Gli operatori bit per bit supportati dal linguaggio D sono elencati nella tabella seguente. Supponiamo che la variabile A contenga 60 e la variabile B ne contenga 13, quindi -

Operatore Descrizione Esempio
& L'operatore AND binario copia un po 'nel risultato se esiste in entrambi gli operandi. (A e B) darà 12, significa 0000 1100.
| L'operatore OR binario copia un bit se esiste in uno degli operandi. (A | B) restituisce 61. Significa 0011 1101.
^ L'operatore XOR binario copia il bit se è impostato in un operando ma non in entrambi. (A ^ B) restituisce 49. Significa 0011 0001
~ Binary Ones Complement Operator è unario e ha l'effetto di "ribaltare" i bit. (~ A) restituisce -61. Significa 1100 0011 in forma di complemento di 2.
<< Operatore binario di spostamento sinistro. Il valore dell'operando sinistro viene spostato a sinistra del numero di bit specificato dall'operando destro. A << 2 dà 240. Significa 1111 0000
>> Operatore binario di spostamento a destra. Il valore dell'operando sinistro viene spostato a destra del numero di bit specificato dall'operando destro. A >> 2 dà 15. Significa 0000 1111.

Esempio

Prova il seguente esempio per comprendere tutti gli operatori bit per bit disponibili nel linguaggio di programmazione D:

import std.stdio;

int main(string[] args) {  
   uint a = 60; /* 60 = 0011 1100 */   
   uint b = 13; /* 13 = 0000 1101 */ 
   int c = 0;  
   
   c = a & b;       /* 12 = 0000 1100 */  
   writefln("Line 1 - Value of c is %d\n", c ); 
   
   c = a | b;       /* 61 = 0011 1101 */ 
   writefln("Line 2 - Value of c is %d\n", c );
   
   c = a ^ b;       /* 49 = 0011 0001 */ 
   writefln("Line 3 - Value of c is %d\n", c ); 
   
   c = ~a;          /*-61 = 1100 0011 */ 
   writefln("Line 4 - Value of c is %d\n", c );  
   
   c = a << 2;     /* 240 = 1111 0000 */ 
   writefln("Line 5 - Value of c is %d\n", c );
   
   c = a >> 2;     /* 15 = 0000 1111 */ 
   writefln("Line 6 - Value of c is %d\n", c );
   
   return 0; 
}

Quando compili ed esegui il programma sopra, produce il seguente risultato:

Line 1 - Value of c is 12  

Line 2 - Value of c is 61
  
Line 3 - Value of c is 49
  
Line 4 - Value of c is -61
  
Line 5 - Value of c is 240
  
Line 6 - Value of c is 15