문자열 포인터를 한 문자 뒤로 이동합니다.
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을 반환하고 errno를 EINVAL로 설정합니다.
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