다음을 통해 공유


IMemAllocator::D ecommit 메서드(strmif.h)

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드가 DirectShow 대신 Media Foundation에서 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

메서드는 Decommit 버퍼 메모리를 해제합니다.

구문

HRESULT Decommit();

반환 값

성공하면 S_OK 반환하거나 오류의 원인을 나타내는 HRESULT 값을 반환합니다.

설명

IMemAllocator::GetBuffer 메서드에서 대기 중인 모든 스레드는 오류와 함께 반환됩니다. IMemAllocator::Commit 메서드가 호출될 때까지 GetBuffer에 대한 추가 호출이 실패합니다.

메서드의 Decommit 목적은 필터가 할당자에서 더 이상 샘플을 가져오지 못하도록 하는 것입니다. 샘플에 대한 참조 횟수가 이미 있는 필터는 영향을 받지 않습니다. 그러나 필터가 샘플을 해제하고 참조 수가 0으로 나면 샘플을 더 이상 사용할 수 없습니다.

할당자는 참조 수가 0인 모든 샘플에 속하는 메모리를 해제할 수 있습니다. 따라서 메서드는 Decommit 필터가 메모리에 대한 액세스 권한을 중지한다는 점에서 메모리를 "해제"합니다. 메모리가 실제로 힙으로 반환되는지 여부는 할당자의 구현에 따라 달라집니다. 일부 할당자는 자체 소멸자 메서드가 될 때까지 기다립니다. 그러나 할당자는 자신을 삭제할 때 할당된 메모리를 남겨 두면 안 됩니다. 따라서 할당자의 소멸자는 모든 샘플이 릴리스될 때까지 기다려야 합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

IMemAllocator 인터페이스