<?php
/*
* Aquí están algunos ejemplos
*/
echo "\n--- Desplazamientos a la derecha sobre enteros positivos ---\n";
$val = 4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'copia del bit de signo ahora a la izquierda');
$val = 4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places);
$val = 4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'bits salieron por la derecha');
$val = 4;
$places = 4;
$res = $val >> $places;
p($res, $val, '>>', $places, 'mismo resultado que arriba: no hay desplazamiento más allá de 0');
echo "\n--- Desplazamientos a la derecha sobre enteros negativos ---\n";
$val = -4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'copia del bit de signo ahora a la izquierda');
$val = -4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places, 'bits salieron por la derecha');
$val = -4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'mismo resultado que arriba: no hay desplazamiento más allá de -1');
echo "\n--- Desplazamientos a la izquierda sobre enteros positivos ---\n";
$val = 4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'complemento de ceros a la derecha');
$val = 4;
$places = (PHP_INT_SIZE * 8) - 4;
$res = $val << $places;
p($res, $val, '<<', $places);
$val = 4;
$places = (PHP_INT_SIZE * 8) - 3;
$res = $val << $places;
p($res, $val, '<<', $places, 'el bit de signo salió');
$val = 4;
$places = (PHP_INT_SIZE * 8) - 2;
$res = $val << $places;
p($res, $val, '<<', $places, 'bits salieron a la izquierda');
echo "\n--- Desplazamientos a la izquierda sobre enteros negativos ---\n";
$val = -4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'complemento de ceros a la derecha');
$val = -4;
$places = (PHP_INT_SIZE * 8) - 3;
$res = $val << $places;
p($res, $val, '<<', $places);
$val = -4;
$places = (PHP_INT_SIZE * 8) - 2;
$res = $val << $places;
p($res, $val, '<<', $places, 'bits salieron a la izquierda, incluyendo el bit de signo');
/*
* Ignórese esta sección
* Contiene código para el formato de este ejemplo
*/
function p($res, $val, $op, $places, $note = '') {
$format = '%0' . (PHP_INT_SIZE * 8) . "b\n";
printf("Expresión : %d = %d %s %d\n", $res, $val, $op, $places);
echo " Decimal :\n";
printf(" val=%d\n", $val);
printf(" res=%d\n", $res);
echo " Binario :\n";
printf(' val=' . $format, $val);
printf(' res=' . $format, $res);
if ($note) {
echo " Nota : $note\n";
}
echo "\n\n";
}
?>
El resultado del ejemplo en equipos de 32 bit sería:
--- Desplazamientos a la derecha sobre enteros positivos ---
Expresión : 2 = 4 >> 1
Decimal :
val=4
res=2
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000000010
Nota : copia del bit de signo ahora a la izquierda
Expresión : 1 = 4 >> 2
Decimal :
val=4
res=1
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000000001
Expresión : 0 = 4 >> 3
Decimal :
val=4
res=0
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000000000
Nota : bits salieron por la derecha
Expresión : 0 = 4 >> 4
Decimal :
val=4
res=0
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000000000
Nota : mismo resultado que arriba: no hay desplazamiento más allá de 0
--- Desplazamientos a la derecha sobre enteros negativos ---
Expresión : -2 = -4 >> 1
Decimal :
val=-4
res=-2
Binario :
val=11111111111111111111111111111100
res=11111111111111111111111111111110
Nota : copia del bit de signo a la izquierda
Expresión : -1 = -4 >> 2
Decimal :
val=-4
res=-1
Binario :
val=11111111111111111111111111111100
res=11111111111111111111111111111111
Nota : bits salieron por la derecha
Expresión : -1 = -4 >> 3
Decimal :
val=-4
res=-1
Binario :
val=11111111111111111111111111111100
res=11111111111111111111111111111111
Nota : mismo resultado que arriba: no hay desplazamiento más allá de -1
--- Desplazamientos a la izquierda sobre enteros positivos ---
Expresión : 8 = 4 << 1
Decimal :
val=4
res=8
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000001000
Nota : complemento de ceros a la derecha
Expresión : 1073741824 = 4 << 28
Decimal :
val=4
res=1073741824
Binario :
val=00000000000000000000000000000100
res=01000000000000000000000000000000
Expresión : -2147483648 = 4 << 29
Decimal :
val=4
res=-2147483648
Binario :
val=00000000000000000000000000000100
res=10000000000000000000000000000000
Nota : el bit de signo salió
Expresión : 0 = 4 << 30
Decimal :
val=4
res=0
Binario :
val=00000000000000000000000000000100
res=00000000000000000000000000000000
Nota : bits salieron a la izquierda
--- Desplazamientos a la izquierda sobre enteros negativos ---
Expresión : -8 = -4 << 1
Decimal :
val=-4
res=-8
Binario :
val=11111111111111111111111111111100
res=11111111111111111111111111111000
Nota : complemento de ceros a la derecha
Expresión : -2147483648 = -4 << 29
Decimal :
val=-4
res=-2147483648
Binario :
val=11111111111111111111111111111100
res=10000000000000000000000000000000
Expresión : 0 = -4 << 30
Decimal :
val=-4
res=0
Binario :
val=11111111111111111111111111111100
res=00000000000000000000000000000000
Nota : bits salieron a la izquierda, incluyendo el bit de signo
El resultado del ejemplo en equipos de 64 bit sería:
--- Desplazamientos a la derecha sobre enteros positivos ---
Expresión : 2 = 4 >> 1
Decimal :
val=4
res=2
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000010
Nota : copia del bit de signo ahora a la izquierda
Expresión : 1 = 4 >> 2
Decimal :
val=4
res=1
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000001
Expresión : 0 = 4 >> 3
Decimal :
val=4
res=0
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
Nota : bits salieron por la derecha
Expresión : 0 = 4 >> 4
Decimal :
val=4
res=0
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
Nota : mismo resultado que arriba: no hay desplazamiento más allá de 0
--- Desplazamientos a la derecha sobre enteros negativos ---
Expresión : -2 = -4 >> 1
Decimal :
val=-4
res=-2
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111110
Nota : copia del bit de signo ahora a la izquierda
Expresión : -1 = -4 >> 2
Decimal :
val=-4
res=-1
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111111
Nota : bits salieron por la derecha
Expresión : -1 = -4 >> 3
Decimal :
val=-4
res=-1
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111111
Nota : mismo resultado que arriba: no hay desplazamiento más allá de -1
--- Desplazamiento a la izquierda sobre enteros negativos ---
Expresión : 8 = 4 << 1
Decimal :
val=4
res=8
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000001000
Nota : complemento de ceros a la derecha
Expresión : 4611686018427387904 = 4 << 60
Decimal :
val=4
res=4611686018427387904
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0100000000000000000000000000000000000000000000000000000000000000
Expresión : -9223372036854775808 = 4 << 61
Decimal :
val=4
res=-9223372036854775808
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=1000000000000000000000000000000000000000000000000000000000000000
Nota : el bit de signo salió
Expresión : 0 = 4 << 62
Decimal :
val=4
res=0
Binario :
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
Nota : bits salieron a la izquierda
--- Desplazamiento a la izquierda sobre enteros negativos ---
Expresión : -8 = -4 << 1
Decimal :
val=-4
res=-8
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111000
Nota : complemento de ceros a la derecha
Expresión : -9223372036854775808 = -4 << 61
Decimal :
val=-4
res=-9223372036854775808
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=1000000000000000000000000000000000000000000000000000000000000000
Expresión : 0 = -4 << 62
Decimal :
val=-4
res=0
Binario :
val=1111111111111111111111111111111111111111111111111111111111111100
res=0000000000000000000000000000000000000000000000000000000000000000
Nota : bits salieron a la izquierda, incluyendo el bit de signo