是我的php解释器疯了,还是我是.


is my php interpreter going crazy, or am i the one who is...?

我继续在php编码中遇到非常奇怪的行为。这里有一个例子:

<?php 
date_default_timezone_set("Europe/Berlin");
$interval1 = (int) 336000;
$interval2 = (int) 1459200;
$interval3 = (int) 17403000;
$interval4 = (int) 43205760;
$interval5 = (int) 84299520;
$week =  (int) 604800;
?>

当我运行此代码时,我在第8行得到一个"意外的T_INT_CAST错误"WTF?!!前5次铸造效果非常好。当我不进行任何强制转换时,前5个表达式会产生一个整数,最后一个是字符串。我在比较数值时注意到了这一点,显然得到了错误的结果。

以下是十六进制编辑器的输出(如注释中所要求的):

00000000: 3C 3F 70 68 70 20 0A 64  61 74 65 5F 64 65 66 61 
00000010: 75 6C 74 5F 74 69 6D 65  7A 6F 6E 65 5F 73 65 74 
00000020: 28 22 45 75 72 6F 70 65  2F 42 65 72 6C 69 6E 22 
00000030: 29 3B 0A 24 69 6E 74 65  72 76 61 6C 31 20 3D 20 
00000040: 28 69 6E 74 29 20 33 33  36 30 30 30 3B 20 2F 2F 
00000050: 74 65 73 74 20 69 6E 74  65 72 76 61 6C 20 66 72 
00000060: 6F 6D 20 68 74 74 70 3A  2F 2F 65 63 6B 71 75 61 
00000070: 72 74 65 72 73 2E 63 6F  6D 2F 6D 6F 65 74 65 72 
00000080: 77 6F 6C 66 2F 64 69 61  67 72 61 6D 6D 31 2E 68 
00000090: 74 6D 6C 0A 24 69 6E 74  65 72 76 61 6C 32 20 3D 
000000A0: 20 28 69 6E 74 29 20 31  34 35 39 32 30 30 3B 0A 
000000B0: 24 69 6E 74 65 72 76 61  6C 33 20 3D 20 28 69 6E 
000000C0: 74 29 20 31 37 34 30 33  30 30 30 3B 0A 24 69 6E 
000000D0: 74 65 72 76 61 6C 34 20  3D 20 28 69 6E 74 29 20 
000000E0: 34 33 32 30 35 37 36 30  3B 0A 24 69 6E 74 65 72 
000000F0: 76 61 6C 35 20 3D 20 28  69 6E 74 29 38 34 32 39 
00000100: 39 35 32 30 3B 0A 24 77  65 65 6B 20 3D 20 A0 69 
00000110: 6E 74 76 61 6C 28 36 30  34 38 30 30 29 3B

正如您从php代码中的十六进制编辑器中看到的,在intval/(int)casting之前有一个不间断的空间:(第二个空间)

00000100: 39 35 32 30 3B 0A 24 77 65 65 6B 20 3D 20A069

去掉它,你的代码就可以工作了。

您应该考虑

PHP_INT_SIZE

整数的大小取决于平台,尽管最大值约为20亿是通常的值(即32位符号)。64位平台通常具有大约9E18的最大值。PHP不支持无符号整数。整数大小可以使用常量PHP_INT_size来确定,最大值可以使用PHP 4.4.0和PHP 5.0.5以来的常量PHP_INT_MAX来确定。

当尝试从浮点数字转换为整数时,如果浮点值超出整数的边界(在32位平台上通常为+/-2.15e+9=2^31,在64位平台上为+/-9.22e+18=2^63),则结果是未定义的,因为浮点值没有足够的精度来给出精确的整数结果。发生这种情况时,不会发出任何警告,甚至不会发出通知!

尝试更改PHP_INT_SIZE常量并告诉我们发生了什么变化