检查小数中包含哪些标志



我需要检查某个十进制变量中包含哪些十六进制标志。目前脚本只适用于小的小数,但我有一些更长的。

在下面的示例中,当我检查$decimal2中的标志时,它显示了正确的标志,但它不适用于$decimal

我不知道这种行为的原因,也不知道需要改变什么。

这是示例演示。

$decimal = 613090029426844e18; // doesn't work
$decimal2 = 64; //works
const FLAG_1 = 0x1;
const FLAG_2 = 0x2; 
const FLAG_3 = 0x4;
const FLAG_4 = 0x4;
const FLAG_5 = 0x32;
const FLAG_6 = 0x40;
const FLAG_7 = 0x400;

function show_flags ($decimal) {
if ($decimal & FLAG_1) {
echo "Flag 1 included.<br>n";
}
if ($decimal & FLAG_2) {
echo "Flag 2 included.<br>n";
}
if ($decimal & FLAG_3) {
echo "Flag 3 included.<br>n";
}
if ($decimal & FLAG_4) {
echo "Flag 3 included.<br>n";
}
if ($decimal & FLAG_5) {
echo "Flag 3 included.<br>n";
}
if ($decimal & FLAG_6) {
echo "Flag 3 included.<br>n";
}
if ($decimal & FLAG_7) {
echo "Flag 3 included.<br>n";
}
}
show_flags($decimal);

首先,在$decimal中没有设置任何标志,因此预计不会打印任何内容。即使您设置了这些标志,比如通过将0xfff添加到$decimal,它仍然不会打印任何内容,因为数字太大而不能存储为int,所以它被存储为float,这具有有限的精度。你可以在var_dump()

中看到这一点
$decimal = 613090029426844e18; // doesn't work
$decimal2 = 64; //works
var_dump($decimal);
var_dump($decimal2);

输出:

float(6.13090029426844E+32)
int(64)

浮点数只存储最高位(大约14位),任何低位的数字都不可避免地被丢弃。

$decimal3 = 613090029426844e18 + 0xfff;

输出:

float(6.13090029426844E+32)

所以你不能在大数中使用低有效数字。你可能想看看BigInterger类在PHP中有一个BigInteger类吗?

最新更新