DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   PHP (http://www.devprotalk.com/forumdisplay.php?f=9)
-   -   PHP i unsigned int (ili big int) (http://www.devprotalk.com/showthread.php?t=9714)

ivanhoe 21. 02. 2011. 01:52

PHP i unsigned int (ili big int)
 
Kako raditi sa velikim brojevima, tipa facebook id-jevi?

Morao sam da ih prebacim da budu varchar, da bih mogao da ih poredim... php ih izgleda tretira kao float i onda == ne radi kako treba...

dinke 21. 02. 2011. 03:11

PHP sve brojeve vece od limita za INT tip implicitno prebacuje u Float. Imas to lepo opisano u manualu:

http://www.php.net/manual/en/language.types.integer.php

Tako da npr:
PHP kôd:

<?php
$large_number 
2147483647;
var_dump($large_number);                     // int(2147483647)

$large_number 2147483648;
var_dump($large_number);                     // float(2147483648)

Medjutim ti ovde spominjes varchar sto je mysql db type za
nonfixed type string pa mi nije bas najjasnije sta je pisac hteo da kaze :)

Inace mozes da probas neke od tih "math" extenzija, ceo spisak imas ovde.

dinke 21. 02. 2011. 03:12

Btw max vrednost int tipa je definisana konstantom PHP_INT_MAX . Naravno mozes koristiti i vece brojeve, jedino sto ih on tretira kao float.

jablan 21. 02. 2011. 09:00

Citat:

Originalno napisao dinke (Napišite 95678)
PHP sve brojeve vece od limita za INT tip implicitno prebacuje u Float.

No comment (teškom mukom se uzdržava od "poređenja radi" bloka). :)

Šta onda bude:

Kôd:

<?php
$large_number1 = 1234567892147483647;
var_dump($large_number1);                    // float(1.23456789215E+18)

$large_number2 = 1234567892147483648;
var_dump($large_number2);                    // float(1.23456789215E+18)

$result = $large_number1 == $large_number2;
var_dump($result);                            // bool(true)

?>

@ivanhoe: Ako su u pitanju ID-jevi, zašto je problem da ostanu stringovi, obično ti sa njima treba samo poređenje na jednakost.

ivanhoe 21. 02. 2011. 11:05

provalio sam kasnije, problem je zapravo bio u tome sto sam na jednom mestu imao casting u (int), koji je onda naprosto odsecao vrednost na PHP_INT_MAX (bez da baci warning, sto je malo trulo)

A inace, da li je float safe za poredjenje u ovom slucaju implicitnog kastinga za velike brojeve? Obicno se ne preporucuje porediti float vrednosti, mada deluje da u ovom slucaju rade kako treba...


@jablan: samo zbog velicine i brzine indexa po tom polju, mada za ovaj slucaj je u principu nebitno... ali moc navike :)

dinke 21. 02. 2011. 11:15

@jablan
Bolji primer je ovo:

PHP kôd:

<?php 
$large_number1 
PHP_INT_MAX
var_dump($large_number1);                     // int(9223372036854775807)

$large_number2 PHP_INT_MAX+1
var_dump($large_number2);                     // float(9.2233720368548E+18)

$result = ($large_number1 == $large_number2);
var_dump($result);                            // bool(true)

?>

Rezultat isti (bool true). Bez komentara, sreca pa se PHP uglavnom koristi za Web a ovi sto ga koriste za rakete su upoznati za time ;)

jablan 21. 02. 2011. 11:46

Pa dobro, desi se ponekad da veliki brojevi trebaju i onima koji ne prave rakete. :)

Bez neumesnih poređenja (samo komentarišemo): ako su već odlučili da rade implicitnu konverziju kad se pređe limit (što je sasvim OK za jedan high-level jezik), bilo je logično da se konvertuje u arbitrary precision integer (linkovao si već par biblioteka koje se time bave), a ne u float.

marinowski 21. 02. 2011. 11:56

Float brojevi se baš i ne upoređuju na jednakost bez velike potrebe, baš zbog prikazanih problema. Ne važi to samo za PHP, nego za bilo koji programski jezik.

Naročito ako ima dosta računanja, pa se greška nagomila ...

jablan 21. 02. 2011. 12:12

^ Da, zato su tu arbitrary precision i rational tipovi.

McKracken 21. 02. 2011. 13:53

Jablane, ne suzdrzavaj se .. "Poredjenja radi" blok ima tendenciju da postane moj omiljeni blok :D


Vreme je GMT +2. Trenutno vreme je 00:05.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.