_set_fmode

파일 I/O 연산에 대한 기본 파일 변환 모드를 설정합니다.

구문

errno_t _set_fmode(
   int mode
);

매개 변수

mode
원하는 파일 변환 모드(_O_TEXT 또는 _O_BINARY)니다.

반환 값

성공하는 경우 0을 반환하고, 실패하는 경우 오류 코드를 반환합니다. 그렇지 않은 _O_TEXT 경우 mode 또는 _O_BINARY_O_WTEXT매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기가 호출됩니다. 계속해서 실행하도록 허용한 경우 이 함수는 errnoEINVAL로 설정하고 EINVAL을 반환합니다.

설명

이 함수는 전역 변수를 _fmode 설정합니다. 이 변수는 파일 I/O 연산 _open_pipe에 대한 기본 파일 변환 모드를 지정합니다.

_O_TEXT_O_BINARY는 Fcntl.h에 정의됩니다. EINVAL은 Errno.h에 정의됩니다.

기본적으로 이 함수의 전역 상태는 애플리케이션으로 범위가 지정됩니다. 이 동작을 변경하려면 CRT의 전역 상태를 참조하세요.

요구 사항

루틴에서 반환된 값 필수 헤더 선택적 헤더
_set_fmode <stdlib.h> <fcntl.h>, <errno.h>

호환성에 대한 자세한 내용은 호환성을 참조하세요.

예시

// crt_set_fmode.c
#include <stdlib.h>
#include <stdio.h>
#include <fcntl.h>     /* for _O_TEXT and _O_BINARY */
#include <errno.h>     /* for EINVAL */
#include <sys\stat.h>  /* for _S_IWRITE */
#include <share.h>     /* for _SH_DENYNO */

int main()
{
   int mode, fd, ret;
   errno_t err;
   int buf[12] = { 65, 66, 67, 68, 69, 70, 71, 72, 73, 74,
                   75, 76 };
   char * filename = "fmode.out";

   err = _get_fmode(&mode);
   if (err == EINVAL)
   {
      printf( "Invalid parameter: mode\n");
      return 1;
   }
   else
      printf( "Default Mode is %s\n", mode == _O_TEXT ? "text" :
              "binary");

   err = _set_fmode(_O_BINARY);
   if (err == EINVAL)
   {
      printf( "Invalid mode.\n");
      return 1;
   }

   if ( _sopen_s(&fd, filename, _O_RDWR | _O_CREAT, _SH_DENYNO, _S_IWRITE | _S_IREAD) != 0 )
   {
      printf( "Error opening the file %s\n", filename);
      return 1;
   }

   if (ret = _write(fd, buf, 12*sizeof(int)) < 12*sizeof(int))
   {
      printf( "Problem writing to the file %s.\n", filename);
      printf( "Number of bytes written: %d\n", ret);
   }

   if (_close(fd) != 0)
   {
      printf("Error closing the file %s. Error code %d.\n",
             filename, errno);
   }

   system("type fmode.out");
}
Default Mode is binary
A   B   C   D   E   F   G   H   I   J   K   L

참고 항목

_fmode
_get_fmode
_setmode
텍스트 및 이진 모드 파일 I/O