다음을 통해 공유


_strdec, _wcsdec, _mbsdec_mbsdec_l

문자열 포인터를 한 문자 뒤로 이동합니다.

Important

Windows 런타임에서 실행되는 애플리케이션에서는 _mbsdec_mbsdec_l을 사용할 수는 없습니다. 자세한 내용은 유니버설 Windows 플랫폼 앱에서 지원되지 않는 CRT 함수를 참조하세요.

구문

unsigned char *_strdec(
   const unsigned char *start,
   const unsigned char *current
);
unsigned wchar_t *_wcsdec(
   const unsigned wchar_t *start,
   const unsigned wchar_t *current
);
unsigned char *_mbsdec(
   const unsigned char *start,
   const unsigned char *current
);
unsigned char *_mbsdec_l(
   const unsigned char *start,
   const unsigned char *current,
   _locale_t locale
);

매개 변수

start
소스 문자열의 모든 문자(또는 멀티바이트 문자의 첫 번째 바이트)에 대한 _mbsdec _mbsdec_l포인터이며 원본 문자열 start 앞에 와야 합니다 current .

current
소스 문자열의 모든 문자(또는 멀티바이트 문자의 첫 번째 바이트)에 대한 _mbsdec _mbsdec_l포인터이며 원본 문자열 current 에서 따라 start 야 합니다.

locale
사용할 로캘입니다.

반환 값

_mbsdec, _mbsdec_l_strdec_wcsdec 각각은 바로 앞에 current_mbsdec 오는 문자에 대한 포인터를 반환합니다. 값이 해당 값 start 보다 크거나 같은 current경우 반환됩니다NULL. _tcsdec는 이러한 함수 중 하나에 매핑되며 해당 반환 값은 매핑에 따라 달라집니다.

설명

_mbsdec_mbsdec_l 함수는 start가 포함된 문자열에서 current 바로 앞에 있는 멀티바이트 문자의 첫 번째 바이트에 대한 포인터를 반환합니다.

출력 값은 로캘의 LC_CTYPE 범주 설정에 영향을 받습니다. 자세한 내용은 setlocale, _wsetlocale을 참조하세요. _mbsdec는 현재 사용 중인 로캘에 따라 멀티바이트 문자 시퀀스를 인식하고 _mbsdec_l은 전달된 로캘 매개 변수를 대신 사용한다는 점을 제외하고는 동일합니다. 자세한 내용은 Locale을 참조하세요.

이 경우 start 매개 변수 유효성 검사에 설명된 대로 잘못된 매개 변수 처리기가 호출됩니다.current NULL 계속해서 실행하도록 허용한 경우 이 함수는 EINVAL을 반환하고 errnoEINVAL로 설정합니다.

Important

이러한 함수는 버퍼 오버런 위협에 노출될 수 있습니다. 버퍼 오버런은 불필요한 권한 상승을 발생시킬 수 있으므로 시스템 공격에 사용될 수 있습니다. 자세한 내용은 버퍼 오버런 방지를 참조하세요.

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

일반 텍스트 루틴 매핑

Tchar.h 루틴 _UNICODE_MBCS 정의되지 않음 정의된 _MBCS 정의된 _UNICODE
_tcsdec _strdec _mbsdec _wcsdec

_strdec_wcsdec_mbsdec_mbsdec_l의 싱글바이트 문자 및 와이드 문자 버전입니다. _strdec_wcsdec 이 매핑에 대해서만 제공되며, 그렇지 않으면 사용하면 안 됩니다.

자세한 내용은 제네릭 텍스트 매핑제네릭 텍스트 매핑 사용을 참조하세요.

요구 사항

루틴에서 반환된 값 필수 헤더 선택적 헤더
_mbsdec <mbstring.h> <mbctype.h>
_mbsdec_l <mbstring.h> <mbctype.h>
_strdec <tchar.h>
_wcsdec <tchar.h>

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

예시

다음 예에서는 _tcsdec의 사용법을 보여줍니다.

// crt_tcsdec.cpp
// Compile by using: cl /EHsc crt_tcsdec.cpp
#include <iostream>
#include <tchar.h>
using namespace std;

int main()
{
   const TCHAR *str = _T("12345");
   cout << "str: " << str << endl;

   const TCHAR *str2;
   str2 = str + 2;
   cout << "str2: " << str2 << endl;

   TCHAR *answer;
   answer = _tcsdec( str, str2 );
   cout << "answer: " << answer << endl;

   return (0);
}

다음 예에서는 _mbsdec의 사용법을 보여줍니다.

// crt_mbsdec.cpp
// Compile by using: cl /EHsc crt_mbsdec.c
#include <iostream>
#include <mbstring.h>
using namespace std;

int main()
{
   char *str = "12345";
   cout << "str: " << str << endl;

   char *str2;
   str2 = str + 2;
   cout << "str2: " << str2 << endl;

   unsigned char *answer;
   answer = _mbsdec( reinterpret_cast<unsigned char *>( str ), reinterpret_cast<unsigned char *>( str2 ));

   cout << "answer: " << answer << endl;

   return (0);
}

참고 항목

문자열 조작
_strinc, _wcsinc, _mbsinc_mbsinc_l
_strnextc, _wcsnextc, _mbsnextc_mbsnextc_l
_strninc, _wcsninc, _mbsninc_mbsninc_l