Difference between revisions of "cpp/io/manip/left"
From cppreference.com
m (Text replace - "/sidebar" to "/navbar") |
Andreas Krug (Talk | contribs) m (fmt, @@, capitalized 1st letter, {{c}}, ., headers sorted, langlinks) |
||
(13 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
{{cpp/title|left|right|internal}} | {{cpp/title|left|right|internal}} | ||
{{cpp/io/manip/navbar}} | {{cpp/io/manip/navbar}} | ||
− | {{ | + | {{dcl begin}} |
− | {{ | + | {{dcl header|ios}} |
− | {{ | + | {{dcl|num=1| |
std::ios_base& left( std::ios_base& str ); | std::ios_base& left( std::ios_base& str ); | ||
}} | }} | ||
− | {{ | + | {{dcl|num=2| |
std::ios_base& right( std::ios_base& str ); | std::ios_base& right( std::ios_base& str ); | ||
}} | }} | ||
− | {{ | + | {{dcl|num=3| |
std::ios_base& internal( std::ios_base& str ); | std::ios_base& internal( std::ios_base& str ); | ||
}} | }} | ||
− | {{ | + | {{dcl end}} |
− | Modifies the | + | Modifies the positioning of the fill characters in an output stream. {{tt|left}} and {{tt|right}} apply to any type being output, {{tt|internal}} applies to integer, floating-point, and monetary output. Has no effect on input. |
− | 1 | + | @1@ Sets the {{tt|adjustfield}} of the stream {{c|str}} to {{tt|left}} as if by calling {{c|str.setf(std::ios_base::left, std::ios_base::adjustfield)}}. |
− | 2 | + | @2@ Sets the {{tt|adjustfield}} of the stream {{c|str}} to {{tt|right}} as if by calling {{c|str.setf(std::ios_base::right, std::ios_base::adjustfield)}}. |
− | 3 | + | @3@ Sets the {{tt|adjustfield}} of the stream {{c|str}} to {{tt|internal}} as if by calling {{c|str.setf(std::ios_base::internal, std::ios_base::adjustfield)}}. |
− | This is an I/O manipulator | + | The initial default for standard streams is equivalent to {{tt|right}}. |
+ | |||
+ | This is an I/O manipulator. It may be called with an expression such as {{c|out << std::left}} for any {{tt|out}} of type {{lc|std::basic_ostream}} or with an expression such as {{c|in >> std::left}} for any {{tt|in}} of type {{lc|std::basic_istream}}. | ||
===Parameters=== | ===Parameters=== | ||
− | {{ | + | {{par begin}} |
− | {{ | + | {{par|str|reference to I/O stream}} |
− | {{ | + | {{par end}} |
===Return value=== | ===Return value=== | ||
− | + | {{c|str}} (reference to the stream after manipulation). | |
− | {{ | + | |
===Example=== | ===Example=== | ||
{{example | {{example | ||
− | + | |code= | |
− | + | ||
− | + | ||
#include <iomanip> | #include <iomanip> | ||
+ | #include <iostream> | ||
#include <locale> | #include <locale> | ||
+ | |||
int main() | int main() | ||
{ | { | ||
std::cout.imbue(std::locale("en_US.utf8")); | std::cout.imbue(std::locale("en_US.utf8")); | ||
− | std::cout << " | + | |
+ | std::cout << "Default positioning:\n" << std::setfill('*') | ||
<< std::setw(12) << -1.23 << '\n' | << std::setw(12) << -1.23 << '\n' | ||
<< std::setw(12) << std::hex << std::showbase << 42 << '\n' | << std::setw(12) << std::hex << std::showbase << 42 << '\n' | ||
+ | << std::setw(12) << std::put_money(123, true) << "\n\n"; | ||
+ | |||
+ | std::cout << "Left positioning:\n" << std::left | ||
+ | << std::setw(12) << -1.23 << '\n' | ||
+ | << std::setw(12) << 42 << '\n' | ||
<< std::setw(12) << std::put_money(123, true) << "\n\n"; | << std::setw(12) << std::put_money(123, true) << "\n\n"; | ||
− | std::cout << "Internal | + | std::cout << "Internal positioning:\n" << std::internal |
<< std::setw(12) << -1.23 << '\n' | << std::setw(12) << -1.23 << '\n' | ||
<< std::setw(12) << 42 << '\n' | << std::setw(12) << 42 << '\n' | ||
<< std::setw(12) << std::put_money(123, true) << "\n\n"; | << std::setw(12) << std::put_money(123, true) << "\n\n"; | ||
− | std::cout << "Right | + | std::cout << "Right positioning:\n" << std::right |
<< std::setw(12) << -1.23 << '\n' | << std::setw(12) << -1.23 << '\n' | ||
<< std::setw(12) << 42 << '\n' | << std::setw(12) << 42 << '\n' | ||
<< std::setw(12) << std::put_money(123, true) << '\n'; | << std::setw(12) << std::put_money(123, true) << '\n'; | ||
} | } | ||
− | + | |output= | |
− | Left | + | Default positioning: |
+ | *******-1.23 | ||
+ | ********0x2a | ||
+ | ***USD *1.23 | ||
+ | |||
+ | Left positioning: | ||
-1.23******* | -1.23******* | ||
0x2a******** | 0x2a******** | ||
USD *1.23*** | USD *1.23*** | ||
− | Internal | + | Internal positioning: |
-*******1.23 | -*******1.23 | ||
0x********2a | 0x********2a | ||
USD ****1.23 | USD ****1.23 | ||
− | Right | + | Right positioning: |
*******-1.23 | *******-1.23 | ||
********0x2a | ********0x2a | ||
Line 76: | Line 88: | ||
===See also=== | ===See also=== | ||
− | {{ | + | {{dsc begin}} |
− | {{ | + | {{dsc inc|cpp/io/manip/dsc setw}} |
− | {{ | + | {{dsc inc|cpp/io/manip/dsc setfill}} |
− | {{ | + | {{dsc inc|cpp/io/manip/dsc showbase}} |
+ | {{dsc end}} | ||
+ | |||
+ | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} |
Latest revision as of 22:36, 15 September 2023
Defined in header <ios>
|
||
std::ios_base& left( std::ios_base& str ); |
(1) | |
std::ios_base& right( std::ios_base& str ); |
(2) | |
std::ios_base& internal( std::ios_base& str ); |
(3) | |
Modifies the positioning of the fill characters in an output stream. left
and right
apply to any type being output, internal
applies to integer, floating-point, and monetary output. Has no effect on input.
1) Sets the
adjustfield
of the stream str to left
as if by calling str.setf(std::ios_base::left, std::ios_base::adjustfield).2) Sets the
adjustfield
of the stream str to right
as if by calling str.setf(std::ios_base::right, std::ios_base::adjustfield).3) Sets the
adjustfield
of the stream str to internal
as if by calling str.setf(std::ios_base::internal, std::ios_base::adjustfield).The initial default for standard streams is equivalent to right
.
This is an I/O manipulator. It may be called with an expression such as out << std::left for any out
of type std::basic_ostream or with an expression such as in >> std::left for any in
of type std::basic_istream.
Contents |
[edit] Parameters
str | - | reference to I/O stream |
[edit] Return value
str (reference to the stream after manipulation).
[edit] Example
Run this code
#include <iomanip> #include <iostream> #include <locale> int main() { std::cout.imbue(std::locale("en_US.utf8")); std::cout << "Default positioning:\n" << std::setfill('*') << std::setw(12) << -1.23 << '\n' << std::setw(12) << std::hex << std::showbase << 42 << '\n' << std::setw(12) << std::put_money(123, true) << "\n\n"; std::cout << "Left positioning:\n" << std::left << std::setw(12) << -1.23 << '\n' << std::setw(12) << 42 << '\n' << std::setw(12) << std::put_money(123, true) << "\n\n"; std::cout << "Internal positioning:\n" << std::internal << std::setw(12) << -1.23 << '\n' << std::setw(12) << 42 << '\n' << std::setw(12) << std::put_money(123, true) << "\n\n"; std::cout << "Right positioning:\n" << std::right << std::setw(12) << -1.23 << '\n' << std::setw(12) << 42 << '\n' << std::setw(12) << std::put_money(123, true) << '\n'; }
Output:
Default positioning: *******-1.23 ********0x2a ***USD *1.23 Left positioning: -1.23******* 0x2a******** USD *1.23*** Internal positioning: -*******1.23 0x********2a USD ****1.23 Right positioning: *******-1.23 ********0x2a ***USD *1.23
[edit] See also
changes the width of the next input/output field (function) | |
changes the fill character (function template) | |
controls whether prefix is used to indicate numeric base (function) |