|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
[2006-11-29 10:19 UTC] diefans at googlemail dot com
Description: ------------ since version 5.2.0 when I cast a negative float smaller than -2147483648 into an int all bits are lost and the minimum Integer value is returned. For positive floats larger than the max integer value all is fine. It is not possible to perform bitwise calculations with negative overflowing values since all usable information is lost. Reproduce code: --------------- echo (int) -40000000000; echo (int) 40000000000; Expected result: ---------------- -1345294336 1345294336 Actual result: -------------- -2147483648 1345294336 PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Sun Oct 26 11:00:02 2025 UTC |
The logic behind this conversion is quite plain: if (double > LONG_MAX) { long = (unsigned long) double; } else { long = (long) double; } You can try to compile a simple program in C and see that the result is the same.