std::ostrstream:: ostrstream
From cppreference.net
<
cpp
|
io
|
ostrstream
|
ostrstream
(
)
;
|
(1) |
(C++98에서 사용 중단됨)
(C++26에서 제거됨) |
|
ostrstream
(
char
*
s,
int
n,
std::
ios_base
::
openmode
mode
=
std::
ios_base
::
out
)
;
|
(2) |
(C++98에서 사용 중단됨)
(C++26에서 제거됨) |
새로운 출력 strstream과 그 기반이 되는 std::strstreambuf 를 생성합니다.
2)
기본 클래스를 기본 멤버인
std::strstreambuf
의 주소로 초기화했습니다. 이는 사용자가 제공한 고정 크기 배열에 쓰는 두 가지 가능한 방식 중 하나로 초기화됩니다:
a)
app
비트가
mode
에 설정되어 있지 않으면,
strstreambuf
(
s, n, s
)
를 호출하여 버퍼를 구성합니다.
s
가 가리키는 첫 번째 요소를 가진 배열에
n
개보다 적은 요소가 있는 경우 동작은 정의되지 않습니다.
b)
만약
app
비트가
mode
에 설정되어 있으면,
strstreambuf
(
s, n, s
+
std::
strlen
(
s
)
)
를 호출하여 버퍼를 구성합니다.
s
가 가리키는 첫 번째 요소를 갖는 배열에
n
개 미만의 요소가 있거나 배열이 유효한 null-terminated 문자 시퀀스를 포함하지 않는 경우 동작은 정의되지 않습니다.
매개변수
| s | - | 출력 버퍼로 사용할 char 배열 | ||||||||||||||||
| n | - | 출력 버퍼로 사용할 배열의 크기 | ||||||||||||||||
| mode | - |
스트림 열기 모드를 지정합니다. 비트마스크 타입이며, 다음 상수들이 정의되어 있습니다
(비록
app
만 사용되지만):
|
예제
이 코드 실행
#include <iostream> #include <strstream> int main() { std::ostrstream s1; // 동적 버퍼 s1 << 1 << ' ' << 3.14 << " example\n" << std::ends; std::cout << s1.str(); s1.freeze(false); char arr[15] = "Hello"; std::ostrstream s2(arr, sizeof arr, std::ios_base::app); s2 << ", world!" << std::ends; std::cout << s2.str() << '\n'; std::cout << arr << '\n'; // 스트림은 제공된 배열을 사용함 }
출력:
1 3.14 example Hello, world! Hello, world!
참고 항목
strstreambuf
객체를 생성합니다
(
std::strstreambuf
의 public 멤버 함수)
|
|
istrstream
객체를 생성합니다 (선택적으로 버퍼를 할당합니다)
(
std::istrstream
의 public 멤버 함수)
|
|
strstream
객체를 생성합니다 (선택적으로 버퍼를 할당합니다)
(
std::strstream
의 public 멤버 함수)
|