<?php
/*
* Hier kommen die Beispiele.
*/
echo "\n--- RECHTSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---\n";
$val = 4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'Kopie des Vorzeichenbits wird links hereingeschoben');
$val = 4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places);
$val = 4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'Bits werden rechts herausgeschoben');
$val = 4;
$places = 4;
$res = $val >> $places;
p($res, $val, '>>', $places, 'dasselbe Ergebnis wie oben; man kann nicht über 0 hinaus verschieben');
echo "\n--- RECHTSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---\n";
$val = -4;
$places = 1;
$res = $val >> $places;
p($res, $val, '>>', $places, 'Kopie des Vorzeichenbits wird links hereingeschoben');
$val = -4;
$places = 2;
$res = $val >> $places;
p($res, $val, '>>', $places, 'Bits werden rechts herausgeschoben');
$val = -4;
$places = 3;
$res = $val >> $places;
p($res, $val, '>>', $places, 'dasselbe Ergebnis wie oben; man kann nicht über -1 hinaus verschieben');
echo "\n--- LINKSSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---\n";
$val = 4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'Nullen werden rechts hereingeschoben');
$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, 'Vorzeichenbits werden herausgeschoben');
$val = 4;
$places = (PHP_INT_SIZE * 8) - 2;
$res = $val << $places;
p($res, $val, '<<', $places, 'Bits werden links herausgeschoben');
echo "\n--- LINKSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---\n";
$val = -4;
$places = 1;
$res = $val << $places;
p($res, $val, '<<', $places, 'Nullen werden rechts hereingeschoben');
$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 werden links herausgeschoben, einschließlich des Vorzeichenbits');
/*
* Dieser Abschnitt kann ignoriert werden;
* es handlet sich nur um Formatierung, um die Ausgabe deutlicher zu machen.
*/
function p($res, $val, $op, $places, $note = '') {
$format = '%0' . (PHP_INT_SIZE * 8) . "b\n";
printf("Ausdruck: %d = %d %s %d\n", $res, $val, $op, $places);
echo " Dezimal:\n";
printf(" Wert=%d\n", $val);
printf(" Erg.=%d\n", $res);
echo " Binär:\n";
printf(' Wert=' . $format, $val);
printf(' Erg.=' . $format, $res);
if ($note) {
echo " ANMERKUNG: $note\n";
}
echo "\n";
}
?>
Das oben gezeigte Beispiel erzeugt auf 32-Bit-Systemen folgende Ausgabe:
--- RECHTSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---
Ausdruck: 2 = 4 >> 1
Dezimal:
Wert=4
Erg.=2
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000000010
ANMERKUNG: Kopie des Vorzeichenbits wird links hereingeschoben
Ausdruck: 1 = 4 >> 2
Dezimal:
Wert=4
Erg.=1
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000000001
Ausdruck: 0 = 4 >> 3
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000000000
ANMERKUNG: Bits werden rechts herausgeschoben
Ausdruck: 0 = 4 >> 4
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000000000
ANMERKUNG: dasselbe Ergebnis wie oben; man kann nicht über 0 hinaus verschieben
--- RECHTSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---
Ausdruck: -2 = -4 >> 1
Dezimal:
Wert=-4
Erg.=-2
Binär:
Wert=11111111111111111111111111111100
Erg.=11111111111111111111111111111110
ANMERKUNG: Kopie des Vorzeichenbits wird links hereingeschoben
Ausdruck: -1 = -4 >> 2
Dezimal:
Wert=-4
Erg.=-1
Binär:
Wert=11111111111111111111111111111100
Erg.=11111111111111111111111111111111
ANMERKUNG: Bits werden rechts herausgeschoben
Ausdruck: -1 = -4 >> 3
Dezimal:
Wert=-4
Erg.=-1
Binär:
Wert=11111111111111111111111111111100
Erg.=11111111111111111111111111111111
ANMERKUNG: dasselbe Ergebnis wie oben; man kann nicht über -1 hinaus verschieben
--- LINKSSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---
Ausdruck: 8 = 4 << 1
Dezimal:
Wert=4
Erg.=8
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000001000
ANMERKUNG: Nullen werden rechts hereingeschoben
Ausdruck: 1073741824 = 4 << 28
Dezimal:
Wert=4
Erg.=1073741824
Binär:
Wert=00000000000000000000000000000100
Erg.=01000000000000000000000000000000
Ausdruck: -2147483648 = 4 << 29
Dezimal:
Wert=4
Erg.=-2147483648
Binär:
Wert=00000000000000000000000000000100
Erg.=10000000000000000000000000000000
ANMERKUNG: Vorzeichenbits werden herausgeschoben
Ausdruck: 0 = 4 << 30
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=00000000000000000000000000000100
Erg.=00000000000000000000000000000000
ANMERKUNG: Bits werden links herausgeschoben
--- LINKSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---
Ausdruck: -8 = -4 << 1
Dezimal:
Wert=-4
Erg.=-8
Binär:
Wert=11111111111111111111111111111100
Erg.=11111111111111111111111111111000
ANMERKUNG: Nullen werden rechts hereingeschoben
Ausdruck: -2147483648 = -4 << 29
Dezimal:
Wert=-4
Erg.=-2147483648
Binär:
Wert=11111111111111111111111111111100
Erg.=10000000000000000000000000000000
Ausdruck: 0 = -4 << 30
Dezimal:
Wert=-4
Erg.=0
Binär:
Wert=11111111111111111111111111111100
Erg.=00000000000000000000000000000000
ANMERKUNG: Bits werden links herausgeschoben, einschließlich des Vorzeichenbits
Das oben gezeigte Beispiel erzeugt auf 64-Bit-Systemen folgende Ausgabe:
--- RECHTSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---
Ausdruck: 2 = 4 >> 1
Dezimal:
Wert=4
Erg.=2
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000000010
ANMERKUNG: Kopie des Vorzeichenbits wird links hereingeschoben
Ausdruck: 1 = 4 >> 2
Dezimal:
Wert=4
Erg.=1
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000000001
Ausdruck: 0 = 4 >> 3
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000000000
ANMERKUNG: Bits werden rechts herausgeschoben
Ausdruck: 0 = 4 >> 4
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000000000
ANMERKUNG: dasselbe Ergebnis wie oben; man kann nicht über 0 hinaus verschieben
--- RECHTSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---
Ausdruck: -2 = -4 >> 1
Dezimal:
Wert=-4
Erg.=-2
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=1111111111111111111111111111111111111111111111111111111111111110
ANMERKUNG: Kopie des Vorzeichenbits wird links hereingeschoben
Ausdruck: -1 = -4 >> 2
Dezimal:
Wert=-4
Erg.=-1
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=1111111111111111111111111111111111111111111111111111111111111111
ANMERKUNG: Bits werden rechts herausgeschoben
Ausdruck: -1 = -4 >> 3
Dezimal:
Wert=-4
Erg.=-1
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=1111111111111111111111111111111111111111111111111111111111111111
ANMERKUNG: dasselbe Ergebnis wie oben; man kann nicht über -1 hinaus verschieben
--- LINKSSVERSCHIEBUNG MIT POSITIVEN GANZZAHLEN ---
Ausdruck: 8 = 4 << 1
Dezimal:
Wert=4
Erg.=8
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000001000
ANMERKUNG: Nullen werden rechts hereingeschoben
Ausdruck: 4611686018427387904 = 4 << 60
Dezimal:
Wert=4
Erg.=4611686018427387904
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0100000000000000000000000000000000000000000000000000000000000000
Ausdruck: -9223372036854775808 = 4 << 61
Dezimal:
Wert=4
Erg.=-9223372036854775808
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=1000000000000000000000000000000000000000000000000000000000000000
ANMERKUNG: Vorzeichenbits werden herausgeschoben
Ausdruck: 0 = 4 << 62
Dezimal:
Wert=4
Erg.=0
Binär:
Wert=0000000000000000000000000000000000000000000000000000000000000100
Erg.=0000000000000000000000000000000000000000000000000000000000000000
ANMERKUNG: Bits werden links herausgeschoben
--- LINKSVERSCHIEBUNG MIT NEGATIVEN GANZZAHLEN ---
Ausdruck: -8 = -4 << 1
Dezimal:
Wert=-4
Erg.=-8
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=1111111111111111111111111111111111111111111111111111111111111000
ANMERKUNG: Nullen werden rechts hereingeschoben
Ausdruck: -9223372036854775808 = -4 << 61
Dezimal:
Wert=-4
Erg.=-9223372036854775808
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=1000000000000000000000000000000000000000000000000000000000000000
Ausdruck: 0 = -4 << 62
Dezimal:
Wert=-4
Erg.=0
Binär:
Wert=1111111111111111111111111111111111111111111111111111111111111100
Erg.=0000000000000000000000000000000000000000000000000000000000000000
ANMERKUNG: Bits werden links herausgeschoben, einschließlich des Vorzeichenbits