Namespaces
Variants

std::ostrstream:: ostrstream

From cppreference.net
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 를 생성합니다.

1) 기본 동적으로 증가하는 버퍼를 생성하는 방식으로 내부 std::strstreambuf 를 기본 생성하며, 베이스 클래스를 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 만 사용되지만):
상수 설명
app 각 쓰기 전에 스트림의 끝으로 이동
binary 바이너리 모드 로 열기
in 읽기용으로 열기
out 쓰기용으로 열기
trunc 열 때 스트림 내용을 버림
ate 열자마자 스트림의 끝으로 이동
noreplace (C++23) 배타 모드로 열기

예제

#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 멤버 함수)