Heim > Backend-Entwicklung > C++ > Warum funktioniert der Moduloperator in C nicht mit Doubles?

Warum funktioniert der Moduloperator in C nicht mit Doubles?

Patricia Arquette
Freigeben: 2024-12-06 18:39:17
Original
531 Leute haben es durchsucht

Why Doesn't the Modulus Operator Work with Doubles in C  ?

Doppelte Werte und die Moduloperation

Bei der Programmierung berechnet der Moduloperator (%) den Rest, wenn eine Zahl durch eine andere geteilt wird. In C führt jedoch der Versuch, die Modulus-Operation auf zwei Gleitkommazahlen mit doppelter Genauigkeit (Doubles) anzuwenden, zu einem Fehler.

Der folgende Code veranschaulicht dieses Problem:

int main() {
    double x = 6.3;
    double y = 2;
    double z = x % y;
}
Nach dem Login kopieren

Bei der Kompilierung generiert dieser Code einen Fehler:

error: invalid operands of types 'double' and 'double' to binary 'operator%'
Nach dem Login kopieren

Dieser Fehler tritt auf, weil der Modulus-Operator nur für ganzzahlige Operanden definiert ist. Für Doubles ist die entsprechende Funktion fmod(). Um die Modulus-Operation mit Double-Werten zu verwenden, verwenden Sie fmod() wie folgt:

#include <cmath>

int main() {
    double x = 6.3;
    double y = 2.0;
    double z = std::fmod(x, y);
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWarum funktioniert der Moduloperator in C nicht mit Doubles?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage