|
IntegersAn integer is a number of the set Z = {..., -2, -1, 0, 1, 2, ...}. See also: Arbitrary length integer / GMP, Floating point numbers, and Arbitrary precision / BCMath Integers can be specified in decimal (10-based), hexadecimal (16-based) or octal (8-based) notation, optionally preceded by a sign (- or +).
If you use the octal notation, you must precede the number with a
Example 2.1. Integer literals<?php
decimal : [1-9][0-9]*
The size of an integer is platform-dependent, although a
maximum value of about two billion is the usual value
(that's 32 bits signed). PHP does not support unsigned
integers.
Integer size can be determined from
Warning:
If an invalid digit is passed to octal integer (i.e. 8 or 9), the rest of the number is ignored. If you specify a number beyond the bounds of the integer type, it will be interpreted as a float instead. Also, if you perform an operation that results in a number beyond the bounds of the integer type, a float will be returned instead. <?php
Warning:
Unfortunately, there was a bug in PHP so that this
does not always work correctly when there are negative numbers
involved. For example: when you do This is solved in PHP 4.1.0.
There is no integer division operator in PHP.
<?php
To explicitly convert a value to integer, use either
the See also type-juggling. From booleans
When converting from float to integer, the number will be rounded towards zero.
If the float is beyond the boundaries of integer
(usually
Warning:
Never cast an unknown fraction to integer, as this can sometimes lead to unexpected results. <?php See for more information the warning about float-precision.
Caution:
Behaviour of converting to integer is undefined for other types. Currently, the behaviour is the same as if the value was first converted to boolean. However, do not rely on this behaviour, as it can change without notice. Code Examples / Notes » language.types.integerrickard_cedergren
When doing large subtractions on 32 bit unsigned integers the result sometimes end up negative. My example script converts a IPv4 address represented as a 32 bit unsigned integer to a dotted quad (similar to ip2long()), and adds a "fix" to the operation. /************************** * int_oct($ip) * Convert INTeger rep of IP to octal (dotted quad) */ function int_oct($ip) { /* Set variable to float */ settype($ip, float); /* FIX for silly PHP integer syndrome */ $fix = 0; if($ip > 2147483647) $fix = 16777216; if(is_numeric($ip)) { return(sprintf("%u.%u.%u.%u", $ip / 16777216, (($ip % 16777216) + $fix) / 65536, (($ip % 65536) + $fix / 256) / 256, ($ip % 256) + $fix / 256 / 256 ) ); } else { return(''); } } jmw254
Try this one instead: function iplongtostring($ip) { $ip=floatval($ip); // otherwise it is capped at 127.255.255.255 $a=($ip>>24)&255; $b=($ip>>16)&255; $c=($ip>>8)&255; $d=$ip&255; return "$a.$b.$c.$d"; } 09-mar-2007 03:26
To force the correct usage of 32-bit unsigned integer in some functions, just add '+0' just before processing them. for example echo(dechex("2724838310")); will print '7FFFFFFF' but it should print 'A269BBA6' When adding '+0' php will handle the 32bit unsigned integer correctly echo(dechex("2724838310"+0)); will print 'A269BBA6' me
This note applies to machines that are using a 32 bit integer size. I imagine the same results occur in 64 bit machines as well (with the number 2^63-1). -2147483648 falls into the range of 32 bit signed integers (0b10000000000000000000000000000000), yet php treats it as a float. However, -2147483647-1 is treated as an integer. The following code demonstrates: <?php var_dump(-2147483648); //float(-2147483648) var_dump(-2147483647 - 1); //int(-2147483648) ?> Regards 23-dec-2003 06:18
Sometimes you need to parse an unsigned 32 bit integer. Here's a function I 've used: function parse_unsigned_int($string) { $x = (float)$string; if ($x > (float)2147483647) $x -= (float)"4294967296"; return (int)$x; } jacek
On 64 bits machines max integer value is 0x7fffffffffffffff (9 223 372 036 854 775 807).
d_n
Here are some tricks to convert from a "dotted" IP address to a LONG int, and backwards. This is very useful because accessing an IP addy in a database table is very much faster if it's stored as a BIGINT rather than in characters. IP to BIGINT: <?php $ipArr = explode('.',$_SERVER['REMOTE_ADDR']); $ip = $ipArr[0] * 0x1000000 + $ipArr[1] * 0x10000 + $ipArr[2] * 0x100 + $ipArr[3] ; ?> IP as BIGINT read from db back to dotted form: Keep in mind, PHP integer operators are INTEGER -- not long. Also, since there is no integer divide in PHP, we save a couple of S-L-O-W floor (<division>)'s by doing bitshifts. We must use floor(/) for $ipArr[0] because though $ipVal is stored as a long value, $ipVal >> 24 will operate on a truncated, integer value of $ipVal! $ipVint is, however, a nice integer, so we can enjoy the bitshifts. <?php $ipVal = $row['client_IP']; $ipArr = array(0 => floor( $ipVal / 0x1000000) ); $ipVint = $ipVal-($ipArr[0]*0x1000000); // for clarity $ipArr[1] = ($ipVint & 0xFF0000) >> 16; $ipArr[2] = ($ipVint & 0xFF00 ) >> 8; $ipArr[3] = $ipVint & 0xFF; $ipDotted = implode('.', $ipArr); ?> rustamabd@gmail-you-know-what
Be careful with using the modulo operation on big numbers, it will cast a float argument to an int and may return wrong results. For example: <?php $i = 6887129852; echo "i=$i\n"; echo "i%36=".($i%36)."\n"; echo "alternative i%36=".($i-floor($i/36)*36)."\n"; ?> Will output: i=6.88713E+009 i%36=-24 alternative i%36=20 popefelix
Be careful when using integer conversion to test something to see if it evaluates to a positive integer or not. You might get unexpected behaviour. To wit: <?php error_reporting(E_ALL); require_once 'Date.php'; $date = new Date(); print "\$date is an instance of " . get_class($date) . "\n"; $date += 0; print "\$date is now $date\n"; var_dump($date); $foo = new foo(); print "\$foo is an instance of " . get_class($foo) . "\n"; $foo += 0; print "\$foo is now $foo\n"; var_dump($foo); class foo { var $bar = 0; var $baz = "la lal la"; var $bak; function foo() { $bak = 3.14159; } } ?> After the integer conversion, you might expect both $foo and $date to evaluate to 0. However, this is not the case: $date is an instance of Date Notice: Object of class Date could not be converted to int in /home/kpeters/work/sketches/ObjectSketch.php on line 7 $date is now 1 int(1) $foo is an instance of foo Notice: Object of class foo could not be converted to int in /home/kpeters/work/sketches/ObjectSketch.php on line 13 $foo is now 1 int(1) This is because the objects are first converted to boolean before being converted to int. paul
"always round it downwards" It seems to truncate, or round toward zero, rather than downward. If the float is negative, it is rounded up. |