_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
을 반환하고 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