std::basic_ostream<CharT,Traits>::seekp
From cppreference.com
                    
                                        
                    < cpp | io | basic ostream
                    
                                                            
                    |   basic_ostream& seekp( pos_type pos );  | 
(1) | |
|   basic_ostream& seekp( off_type off, std::ios_base::seekdir dir );  | 
(2) | |
Sets the output position indicator of the current associated streambuf object. 
| 
 Behaves as UnformattedOutputFunction (except without actually performing output). After constructing and checking the sentry object,  | 
(since C++11) | 
1) if fail() != true, sets the output position indicator to absolute (relative to the beginning of the file) value pos by calling rdbuf()->pubseekpos(pos, std::ios_base::out). In case of failure, calls setstate(std::ios_base::failbit).
2) if fail() != true, sets the output position indicator to offset off relative to dir by calling rdbuf()->pubseekoff(off, dir, std::ios_base::out). In case of failure, calls setstate(std::ios_base::failbit).
Parameters
| pos | - | absolute position to set the output position indicator to | ||||||||
| off | - | relative position (positive or negative) to set the output position indicator to | ||||||||
| dir | - |  defines base position to apply the relative offset to. It can be one of the following constants:
  | 
Return value
*this
Exceptions
Example
Run this code
#include <iostream> #include <sstream> int main() { std::ostringstream os("hello, world"); os.seekp(7); os << 'W'; os.seekp(0, std::ios_base::end); os << '!'; os.seekp(0); os << 'H'; std::cout << os.str() << '\n'; }
Output:
Hello, World!
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 129 | C++98 | there was no way to indicate a failure | sets failbit on failure
 | 
| LWG 136 | C++98 | seekp could set the input stream
 | 
only sets the output stream | 
| LWG 537 | C++98 | 1. the type of pos was pos_type&2. the type of off was off_type&
 | 
1. corrected to pos_type2. corrected to off_type
 | 
| LWG 2341 | C++98 | the resolution of LWG issue 129 for overload (2) was removed | restored | 
See also
|   returns the output position indicator  (public member function)  | |
|   returns the input position indicator  (public member function of std::basic_istream<CharT,Traits>)  | |
|   sets the input position indicator  (public member function of std::basic_istream<CharT,Traits>)  |