Heim >Backend-Entwicklung >C++ >Warum druckt „std::cout.precision()' standardmäßig keine nachgestellten Nullen?
std::cout.precision() ist eine Funktion zur Steuerung der Anzahl der angezeigten Dezimalstellen für Gleitkommawerte. In bestimmten Szenarien werden nachfolgende Nullen jedoch möglicherweise nicht wie erwartet gedruckt.
Beachten Sie den folgenden Codeausschnitt:
#include <iostream> #include <stdlib.h> int main() { int a = 5; int b = 10; std::cout.precision(4); std::cout << (float)a / (float)b << "\n"; return 0; }
Dieser Code gibt 0,5 statt der erwarteten 0,5000 aus. Dies liegt nicht an den ursprünglichen Integer-Datentypen, sondern an der fehlenden standardmäßigen Unterdrückung von nachgestellten Nullen.
Um nachgestellte Nullen korrekt anzuzeigen, muss der Manipulator std::fixed verwendet werden:
std::cout << std::fixed; std::cout << std::setprecision(4); std::cout << (float)a / (float)b << "\n";
Mit diesem Zusatz gibt der Code nun wie vorgesehen 0,5000 aus. Der std::fixed-Manipulator gibt an, dass der Gleitkommawert mit einer festen Anzahl von Dezimalstellen formatiert werden soll, um sicherzustellen, dass nachgestellte Nullen beibehalten werden.
Das obige ist der detaillierte Inhalt vonWarum druckt „std::cout.precision()' standardmäßig keine nachgestellten Nullen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!