我混淆了我如何用PHPUnit獲取相當大的數量。 我寫了斐波那契數。但在100的情況下,我寫下。如何比較PHP中的大數字?
http://github.com/sanemat/kata-fibonacci-phpunit/commit/b6b2945d2eff1b95e7e25b8be8c7bff11098d44d
我希望這個返回TRUE。 失敗。
http://www.php.net/manual/en/language.types.float.php
我明白'永遠不會比較平等'。如何看待它?最後,我比較to_string對方。 如何比較PHP中的大數?
http://github.com/sanemat/kata-fibonacci-phpunit/commit/70a0e47bc0737be47da8fe8726634edd851d940d
我覺得它是難聞的氣味。但我不知道更好的辦法。 請告訴我你如何斷言它?
====
php > $a = 354224848179261915075;
php > echo $a;
3.5422484817926E+20
php > $b = 3.5422484817926E+20;
php > echo $b;
3.5422484817926E+20
php > echo ($a == $b) ? 'TRUE' : 'FALSE';
FALSE
php > echo gmp_cmp($a, $b);
PHP Warning: gmp_cmp(): Unable to convert variable to GMP - wrong type in php shell code on line 1
php > echo (strval($a) == strval($b)) ? 'TRUE' : 'FALSE';
TRUE
====
environment
$ uname -a
Linux localhost.localdomain 2.6.33.6-147.2.4.fc13.x86_64 #1 SMP Fri Jul 23 17:14:44 UTC 2010 x86_64 x86_64 x86_64 GNU/Linux
$ php --version
PHP 5.3.3 (cli) (built: Jul 22 2010 15:57:00)
Copyright (c) 1997-2010 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies
這裏的問題是,要準確顯示斐波那契100你需要一個長的長整型(96位)。從技術上講,對於PHP中的32位以上的整數,你必須使用一個整數數組,確保從一個元素到另一個元素傳送位,並佔據數量級。如果您不想處理該問題,只需使用BCMath庫。 – stevendesu 2010-10-04 00:40:46
我通過使用BCMath庫解決了我的問題。感謝您的幫助。我想了解更多。你的解釋聽起來不錯,但我不明白。什麼字我可以谷歌嗎? – sanemat 2010-10-04 17:40:06