모두의 코드
C++ 레퍼런스 - ios_base::fmtflags 타입

작성일 : 2011-08-19 이 글은 5910 번 읽혔습니다.

아직 C++ 에 친숙하지 않다면 씹어먹는 C++ 은 어때요?

ios_base::fmtflags

스트림 서식 플래그(format flag) 를 위한 타입

스트림 서식 플래그를 나타내기 위한 비트 마스크(bit mask) 형태의 타입이다. 이 타입은 flags, setf, unsetf와 같은 함수들의 인자 혹은 리턴 타입에 사용된다. 이들 함수에 전달되는 값들은 아래와 같은 멤버 상수들의 조합(OR 연산) 으로 이루어진다.

필드

멤버 상수

하는 일

독립적인 플래그들

boolalpha

bool데이터를 문자열로 나타내고, 그렇게 입력 받는다. (true, false)

showbase

정수 표기시,진법을 명시한다. (0x같은 것)

showpoint

부동 소수점 표기시, 소수점을 명시한다

showpos

양수를 표기시 + 부호를 붙인다.

skipws

입력 작업시 앞에 나오는 공백 문자(whitespace)를 무시한다

unitbuf

매 출력 작업 마다 flush 한다

uppercase

출력 작업시 소문자를 대문자로 출력한다

진법 관련 (basefield)

dec

정수를 10진수 형태로 입출력 한다

hex

정수를 16진수 형태로 입출력 한다.

oct

정수를 8 진수 형태로 입출력 한다

부동소수점 관련 (floatfield)

fixed

부동 소수점 데이터를 고정 소수점(fixed-point) 형태로 표기한다

scientific

부동 소수점 데이터를 과학적 표기(scientific notation)로 출력한다

너비 맞추기 (adjustfield)

internal

필드 너비(field width)에 맞게 채우기 문자(fill character)을 덧붙이되, 내부의 특정 지점에 덧붙여 진다.

left

필드 너비에 맞게 채우기 문자를 덧붙이되, 왼쪽에 덧붙인다.

right

필드 너비에 맞게 채우기 문자를 덧붙이되, 오른쪽에 덧붙인다.

이 때 아래와 같은 비트마스크 상수들은 위 플래그들의 몇 개의 조합을 의미한다. 이들은 setfunsetf 에서 사용된다.

플래그 값

오른쪽과 동일하다

adjustfield

left | right | internal

basefield

dec | oct | hex

floatfield

scientific | fixed

플래그들은 OR 연산자를 통해 하나의 fmtflags 로 조합될 수 있다.

이 상수들은 ios_base 클래스의 public 멤버로 정의되므로, ios_base::hex 와 같이 ios_base 의 멤버라는 것을 직접적으로 명시하여 접근하거나, 이를 상속한 클래스나, 이들의 객체에서 ios::hexcout.hex 와 같이도 접근 가능하다.

참고로 ios_base::fmtflags 타입의 이 값들은 같은 이름을 가진 전역 함수인 조작자들과 혼동되서는 안된다. 이 조작자들은 ios_base::fmtflags 타입으로 사용될 수 없으며 (사실 그들은 함수이다!), 이들 상수를 조작자로도 사용할 수 없다. 예컨대 아래와 같은 차이가 있다.

ios_base::skipws  // ios_base::fmtflags 타입의 상수
  skipws          // 조작자 (전역 함수)

꽤 많은 수의 조작자들이 위 플래그들과 이름이 동일하다. 이들에 대한 설명은 조작자를 참고하면 된다. 이러한 조작자들의 기능은 위 플래그들이 하는 일들과 꽤 유사하다.

예를 들어서 showbase 를 조작자로 사용한다면, 역시 정수 데이터를 표기시 진법을 명시하게 되는데, ios_base::setf 에서 인자로 ios_base::showbase 를 전달했다면 이 경우 역시 정수 데이터 표기시 진법을 명시해 달라는 의미이다. 하는 일을 비슷하지만 절대로 혼동해서 사용해서는 안된다.

실행 예제

/*

이 예제는
http://www.cplusplus.com/reference/iostream/ios_base/fmtflags/
에서 가져왔습니다.

*/
#include <iostream>
using namespace std;

int main() {
  // fmtflags 타입 상수들을 직접 이용하기
  cout.setf(ios_base::hex, ios_base::basefield);
  cout.setf(ios_base::showbase);
  cout << 100 << endl;

  // ios_base 를 상속 받은 ios 에서도 이 멤버들에 접근할 수 있다.
  cout.setf(ios::hex, ios::basefield);
  cout.setf(ios::showbase);
  cout << 100 << endl;

  // 역시 이들을 객체의 멤버 상수들로도 접근할 수 있다.
  cout.setf(cout.hex, cout.basefield);
  cout.setf(cout.showbase);
  cout << 100 << endl;

  // fmtflags 를 타입 자체로도 사용할 수 있다.
  ios_base::fmtflags ff;
  ff = cout.flags();
  ff &= ~cout.basefield;  // basefield 비트들을 초기화 시켜버린다.
  ff |= cout.hex;         // hex 를 설정
  ff |= cout.showbase;    // showbase 를 설정
  cout.flags(ff);
  cout << 100 << endl;

  // 아래는 fmtflags 타입 멤버들을 이용한 것은 아니고
  // 이름이 동일한 조작자 showbase 를 이용한 것이다
  cout << hex << showbase << 100 << endl;

  return 0;
}

실행 결과

연관된 것들

  • ios_base::flags: 서식 플래그를 설정하거나 얻는다.

  • ios_base::setf : 특정 서식 플래그를 설정한다.

  • ios_base::unsetf : 특정 서식 플래그를 초기화 한다.

  • setiosflags : 서식 플래그들을 설정한다 (조작자)

첫 댓글을 달아주세요!
프로필 사진 없음
강좌에 관련 없이 궁금한 내용은 여기를 사용해주세요

    댓글을 불러오는 중입니다..