다음을 통해 공유


_aligned_free_dbg

_aligned_malloc 또는 _aligned_offset_malloc를 사용하여 할당된 메모리 블록을 해제합니다(디버그에만 해당).

void _aligned_free_dbg(    void *memblock );

매개 변수

  • memblock
    _aligned_malloc 또는 _aligned_offset_malloc 함수로 반환된 메모리 블록에 대한 포인터입니다.

설명

_aligned_free_dbg 함수는 _aligned_free 함수의 디버그 버전입니다. _DEBUG를 정의하지 않은 경우 _aligned_free_dbg에 대한 각 호출이 _aligned_free에 대한 호출로 줄어듭니다. _aligned_free 및 _aligned_free_dbg 함수는 둘 다 기본 힙에서 메모리 블록을 해제하지만 _aligned_free_dbg 함수에는 메모리 부족 조건을 시뮬레이션하기 위해 빈 블록을 힙의 연결된 목록에 보관할 수 있는 디버깅 기능이 있습니다.

_aligned_free_dbg는 해제 작업을 수행하기 전에 지정된 파일과 블록 위치 모두에 대해 유효성 검사를 수행합니다. 응용 프로그램에서는 이러한 유효성 검사 정보를 제공하지 않습니다. 메모리 블록이 해제되면 디버그 힙 관리자는 자동으로 사용자 부분 양쪽에 있는 버퍼의 무결성을 확인하며 덮어쓰기가 발생하면 오류 보고서를 만듭니다. _crtDbgFlag 플래그의 _CRTDBG_DELAY_FREE_MEM_DF 비트 필드가 설정되면 빈 블록은 값 0xDD로 채워지고, 빈 블록에는 _FREE_BLOCK 블록 형식이 할당되고, 메모리 블록에 대한 힙의 연결된 목록에서 보관됩니다.

메모리 해제 중 오류가 발생하면 운영 체제에서 제공하는 실패 특성에 대한 정보를 바탕으로 errno가 설정됩니다. 자세한 내용은 errno, _doserrno, _sys_errlist 및 _sys_nerr을 참조하십시오.

기본 힙의 디버그 버전에서 메모리 블록을 할당, 초기화 및 관리하는 방법에 대한 자세한 내용은 CRT 디버그 힙 정보를 참조하세요. 할당 블록 형식과 이러한 형식의 사용 방법에 대한 자세한 내용은 디버그 힙의 블록 형식을 참조하세요. 응용 프로그램의 디버그 빌드 시 표준 힙 함수와 이 함수의 디버그 버전 호출 간의 차이점에 대한 자세한 내용은 힙 할당 함수의 디버그 버전을 참조하세요.

요구 사항

루틴

필수 헤더

_aligned_free_dbg

<crtdbg.h>

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

해당 .NET Framework 항목

해당 사항 없음. 표준 C 함수를 호출하려면 PInvoke를 사용합니다. 자세한 내용은 플랫폼 호출 예제를 참조하십시오.

참고 항목

참조

디버그 루틴