Namespaces
Variants

std::ios_base:: iword

From cppreference.net
long & iword ( int index ) ;

먼저, private 저장소(dynamic array of long 또는 다른 인덱스 가능한 데이터 구조)를 index 가 유효한 인덱스가 되도록 충분히 할당하거나 크기를 조정한 후, long 요소 중 index 인덱스를 가진 private 저장소 요소에 대한 참조를 반환합니다.

이 참조는 이 ios_base 객체에 대한 모든 연산(다른 iword() 호출 포함)으로 무효화될 수 있지만, 저장된 값들은 유지됩니다. 따라서 동일한 인덱스로 나중에 iword ( index ) 을 읽으면 다음 std::basic_ios::copyfmt() 호출까지 동일한 값을 생성합니다. 이 값은 어떤 목적으로든 사용될 수 있습니다. 요소의 인덱스는 이전 xalloc() 호출을 통해 얻어야 하며, 그렇지 않으면 동작이 정의되지 않습니다. 새로운 요소들은 0 으로 초기화됩니다.

함수가 실패할 경우(할당 실패로 인한 가능성 있음) 그리고 * this basic_ios<> 객체 또는 하위 객체의 기본 클래스 하위 객체인 경우, std:: basic_ios <> :: setstate ( badbit ) 를 호출하며, 이는 std::ios_base::failure 를 발생시킬 수 있습니다.

목차

참고 사항

iword 저장소의 일반적인 사용법은 사용자 정의 I/O 조정자에서 사용자 정의 operator<< operator>> 로 정보(예: 사용자 정의 서식 플래그)를 전달하거나 표준 스트림에 임뷰된 사용자 정의 서식 패싯으로 정보를 전달하는 것입니다.

매개변수

인덱스 - 요소의 인덱스 값

반환값

요소에 대한 참조입니다.

예외

badbit 설정 시 std::ios_base::failure 를 throw할 수 있습니다.

예제

#include <iostream>
#include <string>
struct Foo
{
    static int foo_xalloc;
    std::string data; 
    Foo(const std::string& s) : data(s) {}
};
// Foo 객체와 함께 사용할 iword 저장소를 할당합니다
int Foo::foo_xalloc = std::ios_base::xalloc();
// 이 사용자 정의 operator<<는 iword가 1을 보유할 경우 문자열을 역순으로 출력합니다
std::ostream& operator<<(std::ostream& os, Foo& f)
{
    if (os.iword(Foo::foo_xalloc) == 1)
        return os << std::string(f.data.rbegin(), f.data.rend());
    else
        return os << f.data;
}
// 이 I/O 조정자는 iword에 저장된 숫자를 0과 1 사이에서 전환합니다
std::ios_base& rev(std::ios_base& os)
{
    os.iword(Foo::foo_xalloc) = !os.iword(Foo::foo_xalloc);
    return os;
}
int main()
{
    Foo f("example");
    std::cout << f << '\n' << rev << f << '\n' << rev << f << '\n';
}

출력:

example
elpmaxe
example

결함 보고서

다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.

DR 적용 대상 게시된 동작 올바른 동작
LWG 36 C++98 참조가 무효화되면 저장된 값이
유지되지 않을 수 있음
저장된 값은 다음 copyfmt() 호출까지
유지됨
LWG 41 C++98 실패 시 함수 자체가 badbit을 설정하지만,
ios_base 는 해당 인터페이스를 제공하지 않음
badbit은 basic_ios 에 의해 설정됨
(만약 * this 가 해당 기본 클래스 하위 객체인 경우)

참고 항목

필요한 경우 전용 저장소의 크기를 조정하고 지정된 인덱스의 void * 요소에 접근합니다
(public member function)
[static]
pword() iword() 의 인덱스로 사용하기 안전한 프로그램 전체에서 고유한 정수를 반환합니다
(public static member function)