_sprintf_p, _sprintf_p_l, _swprintf_p, _swprintf_p_l_sprintf_p, _sprintf_p_l, _swprintf_p, _swprintf_p_l

형식 문자열에서 매개 변수가 사용되는 순서를 지정하는 기능과 함께 문자열에 형식이 지정된 데이터를 씁니다.Write formatted data to a string with the ability to specify the order that the parameters are used in the format string.

구문Syntax

int _sprintf_p(
   char *buffer,
   size_t sizeOfBuffer,
   const char *format [,
   argument_list]
);
int _sprintf_p_l(
   char *buffer,
   size_t sizeOfBuffer,
   const char *format,
   locale_t locale [,
   argument_list]
);
int _swprintf_p(
   wchar_t *buffer,
   size_t sizeOfBuffer,
   const wchar_t *format [,
   argument_list]
);
int _swprintf_p_l(
   wchar_t *buffer,
   size_t sizeOfBuffer,
   const wchar_t *format,
   locale_t locale [,
   argument_list]
);

매개 변수Parameters

bufferbuffer
출력을 위한 스토리지 위치Storage location for output

sizeOfBuffersizeOfBuffer
저장할 최대 문자 수입니다.Maximum number of characters to store.

formatformat
형식 컨트롤 문자열입니다.Format-control string.

argument_listargument_list
서식 문자열에 대 한 선택적 인수입니다.Optional arguments to the format string.

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

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

반환 값Return Value

기록 된 문자 수 이며, 오류가 발생 한 경우-1입니다.The number of characters written, or -1 if an error occurred.

설명Remarks

_Sprintf_p 함수는 일련의 문자 및 값의 형식을 지정 하 고 버퍼에 저장 합니다.The _sprintf_p function formats and stores a series of characters and values in buffer. Argument_list 의 각 인수 (있는 경우)는 형식으로 해당 형식 지정에 따라 변환 되 고 출력 됩니다.Each argument in the argument_list (if any) is converted and output according to the corresponding format specification in format. Format 인수는 printf 및 wprintf 함수에 대 한 형식 지정 구문을사용 합니다.The format argument uses the format specification syntax for printf and wprintf functions. 기록된 마지막 문자 뒤에 null 문자가 추가됩니다.A null character is appended after the last character written. 중복되는 문자열 간에 복사가 이뤄지면 이 동작은 정의되지 않습니다.If copying occurs between strings that overlap, the behavior is undefined. _Sprintf_psprintf_s 의 차이점은 _sprintf_p 는 위치 매개 변수를 지원 한다는 것입니다 .이를 통해 형식 문자열에서 인수가 사용 되는 순서를 지정할 수 있습니다.The difference between _sprintf_p and sprintf_s is that _sprintf_p supports positional parameters, which allows specifying the order in which the arguments are used in the format string. 자세한 내용은 printf_p 위치 매개 변수를 참조하세요.For more information, see printf_p Positional Parameters.

_swintf_l_sprintf_p의 와이드 문자 버전입니다. _swprintf_p 에 대 한 포인터 인수는 와이드 문자열입니다._swprintf_p is a wide-character version of _sprintf_p; the pointer arguments to _swprintf_p are wide-character strings. _Swprintf_p 의 인코딩 오류 검색은 _sprintf_p에서와 다를 수 있습니다.Detection of encoding errors in _swprintf_p may differ from that in _sprintf_p. _swintf_l 및 fwprintf_p_swintf_l 이 출력을 형식 파일의 대상이 아니라 문자열에 기록 하는 것을 제외 하 고 동일 하 게 동작 합니다. _swprintf_pcount 매개 변수를 사용 하 여을 지정 해야 합니다. 쓸 최대 문자 수입니다._swprintf_p and fwprintf_p behave identically except that _swprintf_p writes output to a string rather than to a destination of type FILE, and _swprintf_p requires the count parameter to specify the maximum number of characters to be written. _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.

_sprintf_p 는 null 종결 문자를 제외 하 고 버퍼에 저장 된 바이트 수를 반환 합니다._sprintf_p returns the number of bytes stored in buffer, not counting the terminating null character. _swprintf_p 는 종료 null 와이드 문자를 제외 하 고 버퍼에 저장 된 와이드 문자 수를 반환 합니다._swprintf_p returns the number of wide characters stored in buffer, not counting the terminating null wide character. 버퍼 또는 형식이 null 포인터 이거나 형식 문자열에 잘못 된 형식 지정 문자가 포함 된 경우 매개 변수 유효성 검사에 설명 된 대로 잘못 된 매개 변수 처리기가 호출 됩니다.If buffer 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, these functions return -1 and set errno to EINVAL.

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

TCHAR.H 루틴TCHAR.H routine _UNICODE 및 _MBCS 정의되지 않음_UNICODE & _MBCS not defined _MBCS 정의됨_MBCS defined _UNICODE 정의됨_UNICODE defined
_stprintf_p_stprintf_p _sprintf_p_sprintf_p _sprintf_p_sprintf_p _swprintf_p_swprintf_p
_stprintf_p_l_stprintf_p_l _sprintf_p_l_sprintf_p_l _sprintf_p_l_sprintf_p_l _swprintf_p_l_swprintf_p_l

요구 사항Requirements

루틴에서 반환된 값Routine 필수 헤더Required header
_sprintf_p, _sprintf_p_l_sprintf_p, _sprintf_p_l <stdio.h><stdio.h>
_swprintf_p, _swprintf_p_l_swprintf_p, _swprintf_p_l <stdio.h> 또는 <wchar.h><stdio.h> or <wchar.h>

호환성에 대한 자세한 내용은 호환성을 참조하세요.For additional compatibility information, see Compatibility.

예제Example

// crt_sprintf_p.c
// This program uses _sprintf_p to format various
// data and place them in the string named buffer.
//

#include <stdio.h>

int main( void )
{
    char     buffer[200],
            s[] = "computer", c = 'l';
    int      i = 35,
            j;
    float    fp = 1.7320534f;

    // Format and print various data:
    j  = _sprintf_p( buffer, 200,
                     "   String:    %s\n", s );
    j += _sprintf_p( buffer + j, 200 - j,
                     "   Character: %c\n", c );
    j += _sprintf_p( buffer + j, 200 - j,
                     "   Integer:   %d\n", i );
    j += _sprintf_p( buffer + j, 200 - j,
                     "   Real:      %f\n", fp );

    printf( "Output:\n%s\ncharacter count = %d\n",
            buffer, j );
}
Output:
   String:    computer
   Character: l
   Integer:   35
   Real:      1.732053

character count = 79

예제Example

// crt_swprintf_p.c
// This is the wide character example which
// also demonstrates _swprintf_p returning
// error code.
#include <stdio.h>

#define BUFFER_SIZE 100

int main( void )
{
    wchar_t buffer[BUFFER_SIZE];
    int     len;

    len = _swprintf_p(buffer, BUFFER_SIZE, L"%2$s %1$d",
                      0, L" marbles in your head.");
    _printf_p( "Wrote %d characters\n", len );

    // _swprintf_p fails because string contains WEOF (\xffff)
    len = _swprintf_p(buffer, BUFFER_SIZE, L"%s",
                      L"Hello\xffff world" );
    _printf_p( "Wrote %d characters\n", len );
}
Wrote 24 characters
Wrote -1 characters

참고자료See also

스트림 I/OStream I/O
_fprintf_p, _fprintf_p_l, _fwprintf_p, _fwprintf_p_l_fprintf_p, _fprintf_p_l, _fwprintf_p, _fwprintf_p_l
fprintf, _fprintf_l, fwprintf, _fwprintf_lfprintf, _fprintf_l, fwprintf, _fwprintf_l
_printf_p, _printf_p_l, _wprintf_p, _wprintf_p_l_printf_p, _printf_p_l, _wprintf_p, _wprintf_p_l
printf, _printf_l, wprintf, _wprintf_lprintf, _printf_l, wprintf, _wprintf_l
sprintf, _sprintf_l, swprintf, _swprintf_l, __swprintf_lsprintf, _sprintf_l, swprintf, _swprintf_l, __swprintf_l
scanf, _scanf_l, wscanf, _wscanf_lscanf, _scanf_l, wscanf, _wscanf_l
sscanf, _sscanf_l, swscanf, _swscanf_lsscanf, _sscanf_l, swscanf, _swscanf_l
sscanf_s, _sscanf_s_l, swscanf_s, _swscanf_s_lsscanf_s, _sscanf_s_l, swscanf_s, _swscanf_s_l
vprintf 함수vprintf Functions
printf_p 위치 매개 변수printf_p Positional Parameters