<?php
/*
* Ecco gli esempi.
*/
echo "\n--- SPOSTAMENTO A DESTRA SU INTERI POSITIVI ---\n";
$val = 4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'copia del bit di segno inserito a sinistra');
$val = 4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places);
$val = 4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'i bit escono dal lato destro');
$val = 4;
$places = 4;
$res = $val >> $places;
p($res, $val, '>>', $places, 'come sopra; non c'è spostamento oltre lo 0');
echo "\n--- SPOSTAMENTO A SINISTRA SU INTERI NEGATIVI ---\n";
$val = -4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'copia del bit di segno inserito a sinistra');
$val = -4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places, 'i bit escono dal lato destro');
$val = -4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'come sopra; non c'è spostamento oltre il -1');
echo "\n--- SPOSTAMENTO A SINISTRA SU INTERI POSITIVI ---\n";
$val = 4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'zeri inseriti a destra');
$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, 'i bit di segno sono spostati');
$val = 4;
$places = (PHP_INT_SIZE * 8) - 2;
$res = $val << $places;
p($res, $val, '<<', $places, 'i bit escono dal lato sinistro');
echo "\n--- SPOSTAMENTO A SINISTRA SU INTERI NEGATIVI ---\n";
$val = -4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'zeri inseriti a destra');
$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, 'i bit escono dal lato sinistro, incluso il bit di segno');
/*
* Ignorare questa sezione finale,
* server solo a formattare per rendere più leggibile il risultato.
*/
function p($res, $val, $op, $places, $note = '') {
$format = '%0' . (PHP_INT_SIZE * 8) . "b\n";
printf("Espressione: %d = %d %s %d\n", $res, $val, $op, $places);
echo " Decimale:\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";
}
?>
Risultato del precedente esempio su macchine a 32 bit:
--- SPOSTAMENTO A DESTRA SU INTERI POSITIVI ---
Espressione: 2 = 4 >> 1
Decimale:
val=4
res=2
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000000010
NOTA: copia del bit di segno inserito a sinistra
Espressione: 1 = 4 >> 2
Decimale:
val=4
res=1
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000000001
Espressione: 0 = 4 >> 3
Decimale:
val=4
res=0
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000000000
NOTA: i bit escono dal lato destro
Espressione: 0 = 4 >> 4
Decimale:
val=4
res=0
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000000000
NOTA: come sopra; non c'è spostamento oltre lo 0
--- SPOSTAMENTO A DESTRA SU INTERI NEGATIVI ---
Espressione: -2 = -4 >> 1
Decimale:
val=-4
res=-2
Binario:
val=11111111111111111111111111111100
res=11111111111111111111111111111110
NOTA: copia del bit di segno inserito a sinistra
Espressione: -1 = -4 >> 2
Decimale:
val=-4
res=-1
Binario:
val=11111111111111111111111111111100
res=11111111111111111111111111111111
NOTA: i bit escono dal lato destro
Espressione: -1 = -4 >> 3
Decimale:
val=-4
res=-1
Binario:
val=11111111111111111111111111111100
res=11111111111111111111111111111111
NOTA: come sopra; non c'è spostamento oltre il -1
--- SPOSTAMENTO A SINISTRA SU INTERI POSITIVI ---
Espressione: 8 = 4 << 1
Decimale:
val=4
res=8
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000001000
NOTA: zeri inseriti a destra
Espressione: 1073741824 = 4 << 28
Decimale:
val=4
res=1073741824
Binario:
val=00000000000000000000000000000100
res=01000000000000000000000000000000
Espressione: -2147483648 = 4 << 29
Decimale:
val=4
res=-2147483648
Binario:
val=00000000000000000000000000000100
res=10000000000000000000000000000000
NOTA:i bit di segno sono spostati
Espressione: 0 = 4 << 30
Decimale:
val=4
res=0
Binario:
val=00000000000000000000000000000100
res=00000000000000000000000000000000
NOTA: i bit escono dal lato sinistro
--- SPOSTAMENTO A SINISTRA SU INTERI NEGATIVI ---
Espressione: -8 = -4 << 1
Decimale:
val=-4
res=-8
Binario:
val=11111111111111111111111111111100
res=11111111111111111111111111111000
NOTA: zeri inseriti a destra
Espressione: -2147483648 = -4 << 29
Decimale:
val=-4
res=-2147483648
Binario:
val=11111111111111111111111111111100
res=10000000000000000000000000000000
Espressione: 0 = -4 << 30
Decimale:
val=-4
res=0
Binario:
val=11111111111111111111111111111100
res=00000000000000000000000000000000
NOTA: i bit escono dal lato sinistro, incluso il bit di segno
Risultato del precedente esempio su macchine a 64 bit:
--- SPOSTAMENTO A DESTRA SU INTERI POSITIVI ---
Espressione: 2 = 4 >> 1
Decimale:
val=4
res=2
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000010
NOTA: copia del bit di segno inserito a sinistra
Espressione: 1 = 4 >> 2
Decimale:
val=4
res=1
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000001
Espressione: 0 = 4 >> 3
Decimale:
val=4
res=0
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
NOTA: i bit escono dal lato destro
Espressione: 0 = 4 >> 4
Decimale:
val=4
res=0
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
NOTA: come sopra; non c'è spostamento oltre lo 0
--- SPOSTAMENTO A DESTRA SU INTERI NEGATIVI ---
Espressione: -2 = -4 >> 1
Decimale:
val=-4
res=-2
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111110
NOTA: copia del bit di segno inserito a sinistra
Espressione: -1 = -4 >> 2
Decimale:
val=-4
res=-1
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111111
NOTA: i bit escono dal lato destro
Espressione: -1 = -4 >> 3
Decimale:
val=-4
res=-1
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111111
NOTA: come sopra; non c'è spostamento oltre il -1
--- SPOSTAMENTO A SINISTRA SU INTERI POSITIVI ---
Espressione: 8 = 4 << 1
Decimale:
val=4
res=8
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000001000
NOTA: zeri inseriti a destra
Espressione: 4611686018427387904 = 4 << 60
Decimale:
val=4
res=4611686018427387904
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0100000000000000000000000000000000000000000000000000000000000000
Espressione: -9223372036854775808 = 4 << 61
Decimale:
val=4
res=-9223372036854775808
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=1000000000000000000000000000000000000000000000000000000000000000
NOTA: i bit di segno sono spostati
Espressione: 0 = 4 << 62
Decimale:
val=4
res=0
Binario:
val=0000000000000000000000000000000000000000000000000000000000000100
res=0000000000000000000000000000000000000000000000000000000000000000
NOTA: i bit escono dal lato sinistro
--- SPOSTAMENTO A SINISTRA SU INTERI NEGATIVI ---
Espressione: -8 = -4 << 1
Decimale:
val=-4
res=-8
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=1111111111111111111111111111111111111111111111111111111111111000
NOTA: zeri inseriti a destra
Espressione: -9223372036854775808 = -4 << 61
Decimale:
val=-4
res=-9223372036854775808
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=1000000000000000000000000000000000000000000000000000000000000000
Espressione: 0 = -4 << 62
Decimale:
val=-4
res=0
Binario:
val=1111111111111111111111111111111111111111111111111111111111111100
res=0000000000000000000000000000000000000000000000000000000000000000
NOTA: i bit escono dal lato sinistro, incluso il bit di segno