PHPの浮動小数点の不正確さの落とし穴をナビゲートします
不正確な浮動小数点数は、PHPの一般的な問題です。答えは、IEEE 754ダブルエシジョン形式を使用して、小数を正確に表現できないようにすることです。 1。0.1または0.2はバイナリの無限ループの小数であり、コンピューターはエラーを切り捨てる必要があります。 2。浮動小数点数を比較する場合、abs($ a -$ b)
フローティングポイント算術は、PHPおよび多くのプログラミング言語での混乱と微妙なバグの一般的な原因です。 PHPは数値を動的に処理しますが、IEEE 754のダブルプレシジョンフローティングポイント形式の根本的な使用は、すべての小数を正確に表すことができるわけではないことを意味します。これは、特に金融計算や比較を行うときに、開発者を驚かせる可能性のある不正確さにつながります。

PHPの浮動小数点の不正確さを管理するための重要な落とし穴と実用的な戦略を歩きましょう。
1.なぜ浮動小数点数が不正確なのか
コンピューターはバイナリの浮動小数点数を表していますが、多くの10進数( 0.1
または0.2
など)には無限のバイナリ表現があります。例えば:

$ a = 0.1 0.2; echo $ a; //出力:0.30000000000000004
これはPHPバグではありません。これは、ハードウェアレベルでの浮動小数点数学の仕組みです。結果は0.3
に非常に近いですが、正確に0.3
ではありません。
これは次のとおりです。

- バイナリの
0.1
は繰り返し分数です(小数点以下の1/3など)。 - コンピューターは、有限メモリに収まるように丸くする必要があります。
- これらの小さな丸めエラーは、算術中に蓄積されます。
2。 ==
を使用して、浮動小数点数を比較しないでください
直接的な平等チェックは、小さな精密エラーのためにしばしば失敗します。
var_dump(0.1 0.2 == 0.3); // 間違い!
代わりに、許容範囲(Epsilon)を使用して、2つのフロートが「十分に近い」かどうかを確認します。
function float sakeal($ a、$ b、$ epsilon = 0.00001){ abs($ a -$ b)<$ epsilon; } var_dump(floatal(0.1 0.2、0.3)); // 真実
必要な精度に基づいて$epsilon
を選択してください。金融アプリの場合、 0.00001
でさえ緩すぎるかもしれません。代わりに整数(例、セント)の作業を検討してください。
3.財務計算のために浮動小数点を避けてください
$10.99
のような通貨値をフロートとして保存しないでください。わずかな丸めエラーでさえ、合計、税金、または残高に矛盾を引き起こす可能性があります。
✅ベストプラクティス:整数(セント)または任意の精度ライブラリを使用した文字列を使用します
//セントで保存します $ price1 = 1099; // $ 10.99 $ price2 = 250; // $ 2.50 $合計= $ price1 $ price2; // 1349セント= $ 13.49
または、PHPのBC MathまたはGMP拡張機能を任意の精度に使用します。
// BC MATHを使用します Echo BCADD( '0.1'、 '0.2'、2); // '0.30' Echo Bcmul( '1.25'、 '3.10'、2); // '3.87'
BC Math機能は数字を文字列として扱い、正確に10進算数を実行します。これはお金に最適です。
4。整数に変換するときは注意してください
整数へのフロートをキャストすると、改善はオフ1つのエラーにつながる可能性があります。
$ float = 0.99 * 100; // 99でなければなりません echo(int)$ float; // 98を印刷するかもしれません!
なぜ? 0.99 * 100
98.99999999999999
になるためです。
✅修正:キャスト前の丸
echo(int)round(0.99 * 100); // 99
正確さのためにフロートを整数に変換するときは、常にround()
を使用してください。
5.文字列のフォーマットと表示に注意してください
時々、数字が十分に正確であることがありますが、フォーマットは浮動小数点ノイズを公開します。
printf( "%。20f"、0.1 0.2); // 0.3000000000000004441
number_format()
またはsprintf()
を使用してディスプレイを丸めます。
echo number_format(0.1 0.2、2); // "0.30"
ただし、覚えておいてください。フォーマットは出力のみに影響します。計算の基礎となる精度の問題は修正されません。
ベストプラクティスの概要
-
bcadd()
、bcsub()
、bcmul()
、bcdiv()
財務数学に使用します。 - floatを
==
ではなく、小さな耐性と比較してください。 - 可能な場合は、通貨をセント(整数)に保存します。
- integersにフロートをキャストする前に、常に
round()
。 - cumbory
number_format()
を使用したフォーマット出力フローティングポイントノイズを非表示にします。 - floatの正確な平等に頼らないでください。
浮遊点の不正確さはPHPに固有のものではありませんが、それを無視すると実際のバグにつながる可能性があります。バイナリフローティングポイントの限界を理解し、適切なツール、特にBC MathおよびIntegerベースの算術を使用することにより、ほとんどの落とし穴を回避できます。
基本的に:フロートにお金を扱わせず、正確に平等を信頼しないでください。
以上がPHPの浮動小数点の不正確さの落とし穴をナビゲートしますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











tosetupaphpdevelopmentenvironmentonlinux、instalfpandrequiredextensions、setupawebeberverlikeapacheornginx、testwithaphpfile、andoptionallyinstallmysqlandcomposer.1.installphpandextensionsviapackagemanager(

2つのPHPアレイをマージし、一意の値を保持するには、2つの主要な方法があります。 1.インデックスアレイまたは重複排除のみの場合、array_mergeとarray_uniqueの組み合わせを使用します:最初のマージArray_merge($ array1、$ array2)を使用してから、array_unique()を使用して、最終的にすべての一意の値を含む新しいアレイを取得します。 2。関連アレイと最初の配列のキー値のペアを保持したい場合は、演算子を使用してください。$ result = $ array1 $ array2。これらの2つの方法は、キー名が保持されているか焦点があるかに応じて、異なるシナリオに適用できます。

パスワードの強度を判断するには、定期的な処理と論理処理を組み合わせる必要があります。基本的な要件には以下が含まれます。1。長さは8桁以上です。 2。少なくとも小文字、大文字、および数字を含む。 3。特別な文字制限を追加できます。高度な側面に関しては、文字の継続的な重複と漸進的/減少シーケンスを避ける必要があります。これには、PHP機能検出が必要です。同時に、ブラックリストを導入して、パスワードや123456などの一般的な弱いパスワードをフィルタリングする必要があります。最後に、評価の精度を向上させるためにZXCVBNライブラリを組み合わせることをお勧めします。

PHPファイルのアップロードを安全に処理するには、ソースとタイプを確認し、ファイル名とパスを制御し、サーバー制限を設定し、メディアファイルを2回プロセスする必要があります。 1.トークンを介してCSRFを防ぐためにアップロードソースを確認し、ホワイトリストコントロールを使用してFINFO_FILEを介して実際のMIMEタイプを検出します。 2。ファイルをランダムな文字列に変更し、検出タイプに従って非WEBディレクトリに保存する拡張機能を決定します。 3。PHP構成は、アップロードサイズを制限し、一時的なディレクトリnginx/apacheはアップロードディレクトリへのアクセスを禁止します。 4. GDライブラリは写真を再利用して、潜在的な悪意のあるデータをクリアします。

PHP変数スコープの一般的な問題とソリューションには次のものが含まれます。1。グローバル変数は関数内でアクセスできず、グローバルキーワードまたはパラメーターを使用して渡す必要があります。 2。静的変数は静的で宣言され、1回のみ初期化され、値は複数の呼び出し間で維持されます。 3. $ _GETや$ _POSTなどのハイパーグローバル変数は、任意の範囲で直接使用できますが、安全なフィルタリングに注意を払う必要があります。 4.匿名関数は、使用キーワードを使用して親スコープ変数を導入する必要があり、外部変数を変更する場合は、参照を渡す必要があります。これらのルールを習得すると、エラーを回避し、コードの安定性が向上するのに役立ちます。

PHPコメントコードには3つの一般的な方法があります。1。//#を使用して1行のコードをブロックすると、//を使用することをお勧めします。 2。使用/.../複数の行でコードブロックをラップするには、ネストすることはできませんが交差することができます。 3. / if(){}を使用するなどの組み合わせスキルコメントロジックブロックを制御するか、エディターショートカットキーで効率を改善するには、シンボルを閉じることに注意を払い、使用時にネストを避ける必要があります。

PHPコメントを書くための鍵は、目的と仕様を明確にすることです。コメントは、「何が行われたのか」ではなく「なぜ」を説明する必要があり、冗長性や単純さを避けてください。 1.読みやすさとツールの互換性を向上させるために、クラスおよびメソッドの説明にdocblock(/*/)などの統合形式を使用します。 2。JSジャンプを手動で出力する必要がある理由など、ロジックの背後にある理由を強調します。 3.複雑なコードの前に概要説明を追加し、手順でプロセスを説明し、全体的なアイデアを理解するのに役立ちます。 4. TodoとFixmeを合理的に使用して、To Doアイテムと問題をマークして、その後の追跡とコラボレーションを促進します。優れた注釈は、通信コストを削減し、コードメンテナンスの効率を向上させることができます。

ageneratorinphpisamemory-efficientwaytoateate-overdeatatasetasetasetasetsinging valueseintimeintimeturningthemallatonce.1.generatorsususedeywordproducevaluesedemand、memoryusage.2を還元すること。2
