C++
std :: iomanip
Szukaj…
std :: setw
int val = 10;
// val will be printed to the extreme left end of the output console:
std::cout << val << std::endl;
// val will be printed in an output field of length 10 starting from right end of the field:
std::cout << std::setw(10) << val << std::endl;
To daje:
10
10
1234567890
(tam, gdzie znajduje się ostatni wiersz, aby pomóc zobaczyć przesunięcia znaków).
Czasami musimy ustawić szerokość pola wyjściowego, zwykle gdy potrzebujemy uzyskać dane wyjściowe w uporządkowanym i odpowiednim układzie. Można to zrobić za pomocą std::setw
z std :: iomanip .
Składnia dla std::setw
jest następująca:
std::setw(int n)
gdzie n jest długością pola wyjściowego, które należy ustawić
std :: setprecision
W przypadku użycia w wyrażeniu out << setprecision(n)
lub in >> setprecision(n)
, ustawia parametr precyzji strumienia na zewnątrz lub na dokładnie n. Parametrem tej funkcji jest liczba całkowita, która jest nową wartością precyzji.
Przykład:
#include <iostream>
#include <iomanip>
#include <cmath>
#include <limits>
int main()
{
const long double pi = std::acos(-1.L);
std::cout << "default precision (6): " << pi << '\n'
<< "std::precision(10): " << std::setprecision(10) << pi << '\n'
<< "max precision: "
<< std::setprecision(std::numeric_limits<long double>::digits10 + 1)
<< pi << '\n';
}
//Output
//default precision (6): 3.14159
//std::precision(10): 3.141592654
//max precision: 3.141592653589793239
std :: setfill
Kiedy użyte w wyrażeniu out << setfill(c)
ustawia znak wypełnienia strumienia na c
.
Uwaga: Bieżący znak wypełnienia można uzyskać za pomocą std::ostream::fill
.
Przykład:
#include <iostream>
#include <iomanip>
int main()
{
std::cout << "default fill: " << std::setw(10) << 42 << '\n'
<< "setfill('*'): " << std::setfill('*')
<< std::setw(10) << 42 << '\n';
}
//output::
//default fill: 42
//setfill('*'): ********42
std :: setiosflags
W przypadku użycia w wyrażeniu out << setiosflags(mask)
lub in >> setiosflags(mask)
, ustawia wszystkie flagi formatu strumienia na zewnątrz lub na zewnątrz, zgodnie z określeniem maski.
Lista wszystkich std::ios_base::fmtflags
:
-
dec
- użyj dziesiętnej podstawy dla liczb całkowitych we / wy -
oct
- użyj ósemkowej podstawy dla liczb całkowitych we / wy -
hex
- użyj szesnastkowej podstawy dla liczb całkowitych we / wy -
basefield
-dec|oct|hex|0
przydatne do operacji maskowania -
left
- left dopasowanie (dodaj znaki wypełnienia po prawej) -
right
- prawe dopasowanie (dodaje znaki wypełnienia po lewej) -
internal
- korekta wewnętrzna (dodaje znaki wypełnienia do wyznaczonego punktu wewnętrznego) -
adjustfield
-left|right|internal
. Przydatne do operacji maskowania -
scientific
- generuj typy zmiennoprzecinkowe za pomocą notacji naukowej lub notacji szesnastkowej, jeśli są połączone z ustaloną -
fixed
- generuj typy zmiennoprzecinkowe za pomocą stałej notacji lub notacji szesnastkowej, jeśli są połączone z naukową -
floatfield
-scientific|fixed|(scientific|fixed)|0
. Przydatne do operacji maskowania -
boolalpha
- wstaw i wyodrębnij typbool
w formacie alfanumerycznym -
showbase
- generuje prefiks wskazujący podstawę liczbową dla wyjścia liczb całkowitych, wymaga wskaźnika waluty we / wy monetarnym -
showpoint
-showpoint
generuje znak dziesiętny dla wyniku liczb zmiennoprzecinkowych -
showpos
- generuje znak+
dla nieujemnego wyniku liczbowego -
skipws
- pomiń wiodące białe znaki przed pewnymi operacjami wprowadzania -
unitbuf
wyjście po każdej operacji wyjścia -
uppercase
- zamień niektóre małe litery odpowiednikami wielkich liter w niektórych operacjach wyjściowych
Przykład manipulatorów:
#include <iostream>
#include <string>
#include<iomanip>
int main()
{
int l_iTemp = 47;
std::cout<< std::resetiosflags(std::ios_base::basefield);
std::cout<<std::setiosflags( std::ios_base::oct)<<l_iTemp<<std::endl;
//output: 57
std::cout<< std::resetiosflags(std::ios_base::basefield);
std::cout<<std::setiosflags( std::ios_base::hex)<<l_iTemp<<std::endl;
//output: 2f
std::cout<<std::setiosflags( std::ios_base::uppercase)<<l_iTemp<<std::endl;
//output 2F
std::cout<<std::setfill('0')<<std::setw(12);
std::cout<<std::resetiosflags(std::ios_base::uppercase);
std::cout<<std::setiosflags( std::ios_base::right)<<l_iTemp<<std::endl;
//output: 00000000002f
std::cout<<std::resetiosflags(std::ios_base::basefield|std::ios_base::adjustfield);
std::cout<<std::setfill('.')<<std::setw(10);
std::cout<<std::setiosflags( std::ios_base::left)<<l_iTemp<<std::endl;
//output: 47........
std::cout<<std::resetiosflags(std::ios_base::adjustfield)<<std::setfill('#');
std::cout<<std::setiosflags(std::ios_base::internal|std::ios_base::showpos);
std::cout<<std::setw(10)<<l_iTemp<<std::endl;
//output +#######47
double l_dTemp = -1.2;
double pi = 3.14159265359;
std::cout<<pi<<" "<<l_dTemp<<std::endl;
//output +3.14159 -1.2
std::cout<<std::setiosflags(std::ios_base::showpoint)<<l_dTemp<<std::endl;
//output -1.20000
std::cout<<setiosflags(std::ios_base::scientific)<<pi<<std::endl;
//output: +3.141593e+00
std::cout<<std::resetiosflags(std::ios_base::floatfield);
std::cout<<setiosflags(std::ios_base::fixed)<<pi<<std::endl;
//output: +3.141593
bool b = true;
std::cout<<std::setiosflags(std::ios_base::unitbuf|std::ios_base::boolalpha)<<b;
//output: true
return 0;
}