<?php
/*
* A lição deste exemplo está na saída
* e não no código do PHP em si.
*/
$magnitude_lower = pow(2, (PHP_INT_SIZE * 8) - 2);
p($magnitude_lower - 1);
p($magnitude_lower, 'Percebeu a rolagem? Veja da próxima vez...');
p(PHP_INT_MAX, 'PHP_INT_MAX');
p(~PHP_INT_MAX, 'interpretado como um a mais que PHP_INT_MAX');
if (PHP_INT_SIZE == 4) {
$note = 'interpretado como o maior inteiro sem sinal';
} else {
$note = 'interpretado como o maior inteiro sem sinal
(18446744073709551615) porém distorcido pela precisão de float';
}
p(-1, $note);
function p($input, $note = '') {
echo "entrada: $input\n";
$format = '%0' . (PHP_INT_SIZE * 8) . 'b';
$bin = sprintf($format, $input);
echo "binário: $bin\n";
ini_set('precision', 20); // Para legibilidade em máquinas 64 bits.
$dec = bindec($bin);
echo 'bindec(): ' . $dec . "\n";
if ($note) {
echo "NOTA: $note\n";
}
echo "\n";
}
?>
Saída do exemplo acima em máquinas de 32 bits:
input: 1073741823
binary: 00111111111111111111111111111111
bindec(): 1073741823
input: 1073741824
binary: 01000000000000000000000000000000
bindec(): 1073741824
NOTE: Percebeu a rolagem? Veja da próxima vez...
input: 2147483647
binary: 01111111111111111111111111111111
bindec(): 2147483647
NOTE: PHP_INT_MAX
input: -2147483648
binary: 10000000000000000000000000000000
bindec(): 2147483648
NOTE: interpretado como um a mais que PHP_INT_MAX
input: -1
binary: 11111111111111111111111111111111
bindec(): 4294967295
NOTE: interpretado como o maior inteiro sem sinal
Saída do exemplo acima em máquinas de 64 bits:
input: 4611686018427387903
binary: 0011111111111111111111111111111111111111111111111111111111111111
bindec(): 4611686018427387903
input: 4611686018427387904
binary: 0100000000000000000000000000000000000000000000000000000000000000
bindec(): 4611686018427387904
NOTE: Percebeu a rolagem? Veja da próxima vez...
input: 9223372036854775807
binary: 0111111111111111111111111111111111111111111111111111111111111111
bindec(): 9223372036854775807
NOTE: PHP_INT_MAX
input: -9223372036854775808
binary: 1000000000000000000000000000000000000000000000000000000000000000
bindec(): 9223372036854775808
NOTE: interpretado como um a mais que PHP_INT_MAX
input: -1
binary: 1111111111111111111111111111111111111111111111111111111111111111
bindec(): 18446744073709551616
NOTE: interpretado como o maior inteiro sem sinal
(18446744073709551615) porém distorcido pela precisão de float