Согласно этому посту -> Как получить двоичное представление числа с плавающей точкой в PHP?
функция floatToBinStr ($ value) используется для представления чисел с плавающей запятой / двойников в двоичном коде в PHP.
Если я позвоню с этим параметром:
floatToBinStr(PHP_INT_MAX + 1);
Я получаю это двоичное представление:
0100001111100000000000000000000000000000000000000000000000000000
64 бита, самый левый бит — это 63-й бит, так как 64-й бит используется для отрицательных операций с плавающей запятой, кажется, что все работает нормально.
У меня есть функция, которая возвращает позицию крайнего левого бита, установленного в единицу с данным числом в качестве параметра, и я заметил, что если я передам значения больше PHP_INT_MAX (например)
public function getPositionOfLeftMostBitSetTo1($n) {
$masks = array(0x1, 0x2, 0xC, 0xF0, 0xFF00, 0xFFFF0000, 0xFFFFFFFF00000000);
$positions = array(1, 2, 2, 4, 8, 16, 32);
$r = ($n < 0) ? -1 : 0);
for ($i = PHP_INT_SIZE == 8 ? 6 : 5; $i >= 0; $i--)
{
if ($n & $masks[$i]) {
$n >>= $positions[$i];
$r += $positions[$i];
}
}
return $r;
}
echo getPositionOfLeftMostBitSetTo1(PHP_INT_MAX + 1);
Я получаю 65 в качестве выхода. Если я попробую это:
echo decbin(PHP_INT_MAX + 1); // PHP_INT_MAX + 1 = 9.22337203685E+18
Я понял
1000000000000000000000000000000000000000000000000000000000000000
Таким образом, похоже, что самый левый бит — 64-й, хотя это неверно, потому что это не отрицательное число с плавающей запятой, и моя функция не возвращается должным образом, а вместо этого возвращает 65, потому что она действует так, как будто она сдвигается вправо на отрицательном ква …
Как я могу заставить PHP распознавать числа с плавающей запятой / двойники больше, чем PHP_INT_MAX, как они должны, и безопасно выполнять побитовые операции над ними?
Спасибо за внимание!
Я решил преобразовать число с плавающей запятой в двоичное с помощью функции floatToBinStr ($ value), а затем использовал bindec, чтобы преобразовать это двоичное представление в целое число, по которому я могу без проблем сдвигаться, в конце цель getPositionOfLeftMostBitSetTo1 () — вернуть позиция самого левого бита установлена в единицу, больше ничего, поэтому преобразование этого двоичного числа с плавающей точкой в любое целое число будет выполнено.
Других решений пока нет …