Diferencia entre revisiones de «and bit a bit»

De ArduWiki
Saltar a: navegación, buscar
(Ejemplo)
(Vea también)
(No se muestra una edición intermedia del mismo usuario)
Línea 37: Línea 37:
  
 
== Vea también ==
 
== Vea también ==
* [[not]] <nowiki>(!)</nowiki>
+
<categorytree mode=all>Operador bit a bit</categorytree>
* [[and]] <nowiki>(&&)</nowiki>
+
<categorytree mode=all>Operador logico</categorytree>
* [[or]] <nowiki>(||)</nowiki>
+
<categorytree mode=all>Funciones bit y byte</categorytree>
* [[not bit a bit]] <nowiki>(~)</nowiki>
 
* [[or bit a bit]] <nowiki>(|)</nowiki>
 
* [[bitshift right]] <nowiki>(>>)</nowiki>
 
* [[bitshift left]] <nowiki>(<<)</nowiki>
 
  
 
== Referencias externas ==
 
== Referencias externas ==

Revisión del 13:46 14 jul 2019

Descripción

El operador binario bit a bit AND es representado por el caracter et (ampersand) &. AND establece (pone en 1) un bit sí y solo si el bit de esa posición está establecido (en 1) en ambos operandos.

a b a & b
0 0 0
1 0 0
0 1 0
1 1 1

Nota: esta operación también es utilizada para borrar (poner en cero) uno o varios bits específicos en una variable. Todo bit en 1 en el segundo operando, se quedará como está; mientras que todo bit en cero se borrará


Sintaxis

op1 & op2
op1
primer operando, es la variable (de cualquier tipo) a modificar.
op2
segundo operando, es quien va a relizar las modificaciones pertinentes.

Retorno

El valor resultante, donde cada bit se establece sólo si lo está en ambos operandos.

Advertencias

  • No confundir el operador bit a bit and (&) con el boleano and (&&).
  • Idealmente ambos operandos deberían ser del mismo tipo (tamaño); en caso de no ser así, solo se operará con los bytes menos significativos del segundo, o se podrían borrar bits si este es el más pequeño.

Ejemplo

char n = -64;
n &= B01111111;    //Con esto lo acabo de convertir en positivo; mientras que los demás bits no me interesan, por eso no los toco.

Vea también

  and
  not
  or
  xor


Referencias externas