vfprintf_s, _vfprintf_s_l, vfwprintf_s, _vfwprintf_s_lvfprintf_s, _vfprintf_s_l, vfwprintf_s, _vfwprintf_s_l

인수 목록에 대한 포인터를 사용하여 형식이 지정된 출력을 씁니다.Write formatted output using a pointer to a list of arguments. 이러한 함수는 CRT의 보안 기능에 설명된 대로 강화된 보안 기능이 있는 vfprintf, _vfprintf_l, vfwprintf, _vfwprintf_l의 버전입니다.These are versions of vfprintf, _vfprintf_l, vfwprintf, _vfwprintf_l with security enhancements as described in Security Features in the CRT.

구문Syntax

int vfprintf_s(  
   FILE *stream,  
   const char *format,  
   va_list argptr   
);  
int _vfprintf_s_l(  
   FILE *stream,  
   const char *format,  
   locale_t locale,  
   va_list argptr   
);  
int vfwprintf_s(  
   FILE *stream,  
   const wchar_t *format,  
   va_list argptr   
);  
int _vfwprintf_s_l(  
   FILE *stream,  
   const wchar_t *format,  
   locale_t locale,  
   va_list argptr   
);  

매개 변수Parameters

stream
FILE 구조체에 대한 포인터입니다.Pointer to FILE structure.

format
형식 사양입니다.Format specification.

argptr
인수 목록에 대한 포인터입니다.Pointer to list of arguments.

locale
사용할 로캘입니다.The locale to use.

자세한 내용은 형식 사양을 참조하세요.For more information, see Format Specifications.

반환 값Return Value

vfprintf_svfwprintf_s는 null 종결 문자를 포함하지 않고 작성된 문자 수를 반환하거나, 출력 오류가 발생하는 경우 음수 값을 반환합니다.vfprintf_s and vfwprintf_s return the number of characters written, not including the terminating null character, or a negative value if an output error occurs. stream 또는 format이 null 포인터이거나 형식 문자열이 잘못된 형식 지정 문자열을 포함하는 경우 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기가 호출됩니다.If either stream or format is a null pointer, or if the format string contains invalid formatting characters, the invalid parameter handler is invoked, as described in Parameter Validation. 계속해서 실행하도록 허용한 경우 이러한 함수가 -1을 반환하고 errnoEINVAL로 설정합니다.If execution is allowed to continue, the functions return -1 and set errno to EINVAL.

이러한 오류 코드 및 기타 오류 코드에 대한 내용은 _doserrno, errno, _sys_errlist, 및 _sys_nerr을 참조하세요.For information on these and other error codes, see _doserrno, errno, _sys_errlist, and _sys_nerr.

설명Remarks

이러한 함수는 각각 인수 목록에 대한 포인터를 가져오며 지정된 데이터의 형식을 지정하고 stream에 지정된 데이터를 씁니다.Each of these functions takes a pointer to an argument list, then formats and writes the given data to stream.

이러한 함수와 비보안 버전의 차이점은 보안 버전의 경우 format 문자열에 올바른 서식 문자가 포함되어 있는지를 확인한다는 것뿐입니다.These functions differ from the non-secure versions only in that the secure versions check that the format string contains valid formatting characters.

vfwprintf_svfprintf_s의 와이드 문자 버전이며, 이 두 함수는 스트림이 ANSI 모드에서 열리는 경우 동일하게 작동합니다.vfwprintf_s is the wide-character version of vfprintf_s; the two functions behave identically if the stream is opened in ANSI mode. vfprintf_s는 현재 UNICODE 스트림에 대한 출력을 지원하지 않습니다.vfprintf_s doesn't currently support output into a UNICODE stream.

_l 접미사가 있는 이러한 함수 버전은 현재 스레드 로캘 대신 전달된 로캘 매개 변수를 사용하는 경우를 제외하고는 동일합니다.The versions of these functions with the _l suffix are identical except that they use the locale parameter passed in instead of the current thread locale.

중요

format 이 사용자 정의 문자열이 아닌지 확인하세요.Ensure that format is not a user-defined string. 자세한 내용은 버퍼 오버런 방지를 참조하세요.For more information, see Avoiding Buffer Overruns.

제네릭 텍스트 루틴 매핑Generic-Text Routine Mappings

TCHAR.H 루틴TCHAR.H routine _UNICODE 및 _MBCS 정의되지 않음_UNICODE & _MBCS not defined _MBCS 정의됨_MBCS defined _UNICODE 정의됨_UNICODE defined
_vftprintf_s vfprintf_s vfprintf_s vfwprintf_s
_vftprintf_s_l _vfprintf_s_l _vfprintf_s_l _vfwprintf_s_l

요구 사항Requirements

루틴에서 반환된 값Routine 필수 헤더Required header 선택적 헤더Optional headers
vfprintf_s, _vfprintf_s_lvfprintf_s, _vfprintf_s_l <stdio.h> 및 <stdarg.h><stdio.h> and <stdarg.h> <varargs.h>*<varargs.h>*
vfwprintf_s, _vfwprintf_s_lvfwprintf_s, _vfwprintf_s_l <stdio.h> 또는 <wchar.h> 및 <stdarg.h><stdio.h> or <wchar.h>, and <stdarg.h> <varargs.h>*<varargs.h>*

* UNIX V 호환성을 위해 필요합니다.* Required for UNIX V compatibility.

호환성에 대한 자세한 내용은 소개 단원의 호환성 부분을 참조하십시오.For additional compatibility information, see Compatibility in the Introduction.

참고 항목See Also

스트림 I/O Stream I/O
vprintf 함수 vprintf Functions
fprintf, _fprintf_l, fwprintf, _fwprintf_l fprintf, _fprintf_l, fwprintf, _fwprintf_l
printf, _printf_l, wprintf, _wprintf_l printf, _printf_l, wprintf, _wprintf_l
sprintf, _sprintf_l, swprintf, _swprintf_l, __swprintf_l sprintf, _sprintf_l, swprintf, _swprintf_l, __swprintf_l
va_arg, va_copy, va_end, va_startva_arg, va_copy, va_end, va_start