WN

WN (https://www.wn.se/forum/index.php)
-   Serversidans teknologier (https://www.wn.se/forum/forumdisplay.php?f=4)
-   -   Problem med subtraktion i PHP (https://www.wn.se/forum/showthread.php?t=35881)

FredrikMH 2009-03-20 15:28

Jag förväntade mig inte att springa på detta problemet men så blev det. Egentligen så är det inget problem men jag undrar ändå varför det blir som det blir.

Kod:

echo 11103-11103.35; exit;
På min utvecklingsdator får jag följade resultat:
-0.35000000000036

På en av mina webbservrar får jag:
-0.35

Det jag undrar över är varför min utvecklingsdator räknar fel. Jag är medveten om att division och multiplikation kan ge decimalproblem för processorer men detta är ju en simpel subtraktion.

tartareandesire 2009-03-20 15:33

Vad händer om du skriver 11103.0-11103.35?

Althalos 2009-03-20 17:36

Jag tror att det har att göra med vad som står i PHP-manualen:
Citat:

It is typical that simple decimal fractions like 0.1 or 0.7 cannot be converted into their internal binary counterparts without a small loss of precision. This can lead to confusing results: for example, floor((0.1+0.7)*10) will usually return 7 instead of the expected 8, since the internal representation will be something like 7.9.

This is due to the fact that it is impossible to express some fractions in decimal notation with a finite number of digits. For instance, 1/3 in decimal form becomes 0.3.

So never trust floating number results to the last digit, and never compare floating point numbers for equality. If higher precision is necessary, the arbitrary precision math functions and gmp functions are available.

d.v.s. det är något krux när PHP översätter mellan binärt och tillbaka. Läs mer här: http://se.php.net/float

Jonas 2009-03-20 22:26

Om du kollar phpinfo() och värdet "precision", vad säger det? Eftersom detta direktiv talar om hur många decimaler du hanterar i flyttal.
Kod:

echo (float) 11103 - (float) 11103.35; exit;
Vad händer då?
Citat:

11103 - 11103.35
-0.35
11103.0 - 11103.35
-0.35
(float) 11103 - (float) 11103.35
-0.35

(Mitt precision värde är 20)
Får jag på min server.

iXam 2009-03-23 04:01

; The number of significant digits displayed in floating point numbers.
precision = 12

i php.ini kanske kan ha något med saken att göra?

coredev 2009-03-23 10:13

Citat:

Originally posted by FredrikMH@Mar 20 2009, 16:28
Jag förväntade mig inte att springa på detta problemet men så blev det. Egentligen så är det inget problem men jag undrar ändå varför det blir som det blir.
Kod:

echo 11103-11103.35; exit;
På min utvecklingsdator får jag följade resultat:
-0.35000000000036
På en av mina webbservrar får jag:
-0.35
Det jag undrar över är varför min utvecklingsdator räknar fel. Jag är medveten om att division och multiplikation kan ge decimalproblem för processorer men detta är ju en simpel subtraktion.

Båda dina datorer räknar rätt kan man säga!

Flyttal är dyrt att räkna och lagra, och därför gör man ofta en approximation. Det skall du alltid ha i minnet när du räknar med decimaler. 1/3 = 0.333333... går t.ex. inte att lagra som ett komplett tal, då de har ett oändligt antal decimaler. Vad man gör är då är att bara ta med ett visst antal decimaler, så kallad precision (se iXams inlägg). Tal som är både stora och små samidigt är extra besvärliga (t.ex. 12343535.000000034323) på grund av det sättet som man lagrar flyttal.


Alla tider är GMT +2. Klockan är nu 00:43.

Programvara från: vBulletin® Version 3.8.2
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Svensk översättning av: Anders Pettersson