Heim Backend-Entwicklung PHP-Problem PHP-Gleitkomma-Array-Summenfehler

PHP-Gleitkomma-Array-Summenfehler

May 07, 2023 pm 05:57 PM

Im Allgemeinen ist das Summieren von Gleitkomma-Arrays in PHP sehr einfach. Verwenden Sie einfach die Funktion array_sum(). In einigen Sonderfällen können jedoch Fehler bei der Summierung von Gleitkomma-Arrays auftreten. Diese Situation wird normalerweise durch Probleme mit der Gleitkomma-Genauigkeit verursacht. Wie lässt sich also der Gleitkomma-Array-Summenfehler beheben?

Werfen wir zunächst einen Blick auf die Frage der Genauigkeit von Gleitkommazahlen. In Computern werden Gleitkommazahlen in binärer Form gespeichert, es gibt jedoch einige Dezimalzahlen, die nicht durch begrenzte Binärzahlen dargestellt werden können. Beispielsweise können Dezimalzahlen wie 0,1 nicht genau binär dargestellt werden. Daher nähert sich der Computer diesen Dezimalzahlen an, die beim Speichern nicht genau dargestellt werden können, was zu Präzisionsproblemen bei Gleitkommazahlen führt.

Wenn wir eine Reihe von Gleitkommazahlen in einem Array speichern und diese dann mit der Funktion array_sum() summieren, liegt möglicherweise ein Genauigkeitsfehler vor, der sich in einer Dezimalstelle mehr oder weniger äußert. Dies liegt daran, dass die Funktion array_sum() bei der Berechnung nicht die Genauigkeit von Gleitkommazahlen berücksichtigt, sondern direkt Additionsoperationen ausführt.

Also, wie kann man dieses Problem lösen?
Eine Problemumgehung besteht darin, die Gleitkommazahlen mit der Funktion sprintf() zu formatieren, sie in Zeichenfolgen mit der gleichen Anzahl von Ziffern umzuwandeln und dann die Summenoperation durchzuführen. Der Beispielcode lautet wie folgt:

 $arr = [0.1, 0.2, 0.3];
 $sum = 0;
 foreach ($arr as $value) {
     $sum += sprintf("%.2f", $value);
 }
 echo $sum; // 0.60
Nach dem Login kopieren

Im Code verwenden wir die Funktion sprintf(), um jede Gleitkommazahl in eine Zeichenfolge mit zwei Dezimalstellen umzuwandeln, und führen dann die Summenoperation aus, um das Problem des Präzisionsfehlers zu lösen vermieden werden.

Eine weitere Lösung besteht darin, die BC-Mathematikbibliothek zu verwenden, die mathematische Berechnungen mit höherer Präzision ermöglichen kann. Der Beispielcode lautet wie folgt:

 $arr = [0.1, 0.2, 0.3];
 $sum = 0;
 foreach ($arr as $value) {
     $sum = bcadd($sum, $value, 2);
 }
 echo $sum; // 0.60
Nach dem Login kopieren

Im Code verwenden wir die Funktion bcadd(), um die Summenoperation von Gleitkommazahlen durchzuführen. Der dritte Parameter 2 bedeutet Behalten Sie zwei Dezimalstellen bei.

Zusammenfassend lässt sich sagen, dass wir, wenn bei der PHP-Gleitkomma-Array-Summierung ein Fehler auftritt, die Funktion sprintf() oder die BC-Mathematikbibliothek verwenden können, um ihn zu beheben. In der tatsächlichen Entwicklung müssen wir je nach Situation geeignete Lösungen auswählen, um die Genauigkeit und Genauigkeit der Berechnungen sicherzustellen.

Das obige ist der detaillierte Inhalt vonPHP-Gleitkomma-Array-Summenfehler. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. Mar 25, 2025 am 10:37 AM

Die JIT -Kompilierung von PHP 8 verbessert die Leistung, indem häufig ausgeführte Code in den Maschinencode zusammengestellt wird, um Anwendungen mit schweren Berechnungen zugute und die Ausführungszeiten zu reduzieren.

OWASP Top 10 PHP: Beschreiben und mildern gemeinsame Schwachstellen. OWASP Top 10 PHP: Beschreiben und mildern gemeinsame Schwachstellen. Mar 26, 2025 pm 04:13 PM

In dem Artikel werden OWASP Top 10 Schwachstellen in PHP- und Minderungsstrategien erörtert. Zu den wichtigsten Problemen gehören die Injektion, die kaputte Authentifizierung und XSS mit empfohlenen Tools zur Überwachung und Sicherung von PHP -Anwendungen.

PHP Secure-Datei-Uploads: Verhindern von Sicherheitslücken im Zusammenhang mit Datei. PHP Secure-Datei-Uploads: Verhindern von Sicherheitslücken im Zusammenhang mit Datei. Mar 26, 2025 pm 04:18 PM

In dem Artikel wird das Sicherung von PHP -Dateien -Uploads erläutert, um Schwachstellen wie die Code -Injektion zu verhindern. Es konzentriert sich auf die Dateitypvalidierung, den sicheren Speicher und die Fehlerbehandlung, um die Anwendungssicherheit zu verbessern.

PHP -Verschlüsselung: Symmetrische und asymmetrische Verschlüsselung. PHP -Verschlüsselung: Symmetrische und asymmetrische Verschlüsselung. Mar 25, 2025 pm 03:12 PM

In dem Artikel wird die symmetrische und asymmetrische Verschlüsselung in PHP erörtert und ihre Eignung, Leistung und Sicherheitsunterschiede verglichen. Die symmetrische Verschlüsselung ist schneller und für Massendaten geeignet, während asymmetrisch für den sicheren Schlüsselaustausch verwendet wird.

PHP -Authentifizierung & amp; Autorisierung: sichere Implementierung. PHP -Authentifizierung & amp; Autorisierung: sichere Implementierung. Mar 25, 2025 pm 03:06 PM

In dem Artikel wird die Implementierung einer robusten Authentifizierung und Autorisierung in PHP erörtert, um den nicht autorisierten Zugriff zu verhindern, Best Practices zu beschreiben und sicherheitsrelevante Tools zu empfehlen.

PHP -CSRF -Schutz: Wie Sie CSRF -Angriffe verhindern. PHP -CSRF -Schutz: Wie Sie CSRF -Angriffe verhindern. Mar 25, 2025 pm 03:05 PM

In dem Artikel werden Strategien erörtert, um CSRF-Angriffe in PHP zu verhindern, einschließlich der Verwendung von CSRF-Token, selben Cookies und ordnungsgemäßem Sitzungsmanagement.

Wie rufen Sie Daten mit PHP aus einer Datenbank ab? Wie rufen Sie Daten mit PHP aus einer Datenbank ab? Mar 20, 2025 pm 04:57 PM

In Artikel wird das Abrufen von Daten aus Datenbanken mithilfe von PHP, die Schritte, Sicherheitsmaßnahmen, Optimierungstechniken und gemeinsame Fehler bei Lösungen erfasst.

Was ist der Zweck von vorbereiteten Aussagen in PHP? Was ist der Zweck von vorbereiteten Aussagen in PHP? Mar 20, 2025 pm 04:47 PM

Vorbereitete Aussagen in PHP erhöhen die Sicherheit und Effizienz der Datenbank durch Verhinderung der SQL -Injektion und Verbesserung der Abfrageleistung durch Zusammenstellung und Wiederverwendung.

See all articles