다음을 통해 공유


_strdup_dbg, _wcsdup_dbg

malloc의 디버그 버전을 사용하는 _strdup 및 _wcsdup의 버전입니다.

char *_strdup_dbg(    const char *strSource,    int blockType,    const char *filename,    int linenumber  ); wchar_t *_wcsdup_dbg(    const wchar_t *strSource,    int blockType,    const char *filename,    int linenumber  );

매개 변수

  • strSource
    Null 종료 소스 문자열입니다.

  • blockType
    요청된 메모리 블록 형식으로 _CLIENT_BLOCK 또는 _NORMAL_BLOCK입니다.

  • filename
    할당 작업 또는 NULL을 요청한 소스 파일의 이름에 대한 포인터입니다.

  • linenumber
    할당 작업이 요청되었거나 NULL인 소스 파일의 줄 번호입니다.

반환 값

이러한 각 함수는 복사한 문자열의 저장 위치에 대한 포인터를 반환하고 저장소를 할당할 수 없는 경우에는 NULL을 반환합니다.

설명

_DEBUG가 정의되면 이러한 함수가 malloc, _malloc_dbg의 디버그 버전을 사용하여 중복 문자열에 필요한 메모리를 할당한다는 점을 제외하면 _strdup_dbg 및 _wcsdup_dbg 함수는 _strdup 및 _wcsdup와 동일합니다. _malloc_dbg의 디버깅 기능에 대한 자세한 내용은 _malloc_dbg를 참조하세요.

대부분의 경우 이러한 함수를 명시적으로 호출할 필요가 없습니다. 대신 _CRTDBG_MAP_ALLOC 플래그를 정의할 수 있습니다. _CRTDBG_MAP_ALLOC을 정의하면 _strdup 및 _wcsdup에 대한 호출이 각각 _strdup_dbg 및 _wcsdup_dbg로 다시 매핑되고 blockType은 _NORMAL_BLOCK으로 설정됩니다. 따라서 힙 블록을 _CLIENT_BLOCK으로 표시하려는 경우가 아니면 이러한 함수를 명시적으로 호출할 필요가 없습니다. 블록 형식에 대한 자세한 내용은 디버그 힙의 블록 형식을 참조하세요.

제네릭 텍스트 라우팅 매핑

TCHAR.H 루틴

_UNICODE 및 _MBCS 정의되지 않음

_MBCS 정의됨

_UNICODE 정의됨

_tcsdup_dbg

_strdup_dbg

_mbsdup

_wcsdup_dbg

요구 사항

루틴

필수 헤더

_strdup_dbg, _wcsdup_dbg

<crtdbg.h>

호환성에 대한 자세한 내용은 소개 단원의 호환성 부분을 참조하십시오.

라이브러리

모든 디버그 버전의 C 런타임 라이브러리입니다.

해당 .NET Framework 항목

System::String::Clone

참고 항목

참조

문자열 조작(CRT)

_strdup, _wcsdup, _mbsdup

개념

힙 할당 함수의 디버그 버전