std::ios_base::precision - cppreference.com (original) (raw)
| streamsize precision() const; | (1) | | | -------------------------------------------------- | --- | | | streamsize precision( streamsize new_precision ); | (2) | |
Manages the precision (i.e. how many digits are generated) of floating point output performed by std::num_put::do_put.
Returns the current precision.
Sets the precision to the given one. Returns the previous precision.
The default precision, as established by std::basic_ios::init, is 6.
[edit] Parameters
new_precision | - | new precision setting |
---|
[edit] Return value
The precision before the call to the function
[edit] Example
#include int main() { const double d = 12.345678901234; std::cout << "The default precision is " << std::cout.precision() << "\n\n"; std::cout << "With default precision d is " << d << '\n'; std::cout.precision(8); std::cout << "With high precision d is " << d << '\n'; }
Output:
The default precision is 6 With default precision d is 12.3457 With high precision d is 12.345679
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 189 | C++98 | 'precision' was defined as 'the number of digits afterthe decimal point', but it is not correct in some cases | corrected |