共用方式為


_CrtDoForAllClientObjects

針對堆積中的所有 _CLIENT_BLOCK 類型呼叫應用程式提供的函式 (僅限偵錯版本)。

語法

void _CrtDoForAllClientObjects(
   void ( * pfn )( void *, void * ),
   void *context
);

參數

pfn
應用程式提供的函式回呼函式的指標。 此函式的第一個參數指向資料。 第二個參數是傳遞至 _CrtDoForAllClientObjects呼叫的內容指標。

context
要傳遞至應用程式提供之函式的應用程式提供的內容的指標。

備註

_CrtDoForAllClientObjects 函式會在堆積的連結清單中搜尋具有 _CLIENT_BLOCK 類型的記憶體區塊,並在找到此類型的區塊時,呼叫應用程式提供的函式。 找到的區塊和 context 參數會作為引數傳遞至應用程式提供的函式。 應用程式可以在偵錯期間追蹤特定配置群組,方法是透過明確呼叫偵錯堆積函式以配置記憶體,並為區塊指定分派 _CLIENT_BLOCK 區塊類型。 然後就可以分別追蹤這些區塊,並在遺漏偵測期間和記憶體狀態報告期間個別回報這些區塊。

_CRTDBG_ALLOC_MEM_DF如果未開啟旗標的_crtDbgFlag欄位字段,_CrtDoForAllClientObjects請立即傳回 。 若未定義 _DEBUG,將會在前置處理期間移除對 _CrtDoForAllClientObjects 的呼叫。

如需 _CLIENT_BLOCK 類型及其他偵錯函式可以如何使用該類型的詳細資訊,請參閱 Types of blocks on the debug heap呼叫的內容指標。 如需如何在基底堆積偵錯版本中配置、初始化及管理記憶體區塊的相關信息,請參閱 CRT 偵錯堆積詳細數據

如果 pfnNULL,將會叫用無效參數處理常式,如參數驗證 (部分機器翻譯) 中所述。 如果允許繼續執行, errno則會將、 _doserrno_sys_errlist_sys_nerr 設定為 , EINVAL 且函式會傳回 。

需求

常式 必要的標頭
_CrtDoForAllClientObjects <crtdbg.h>、 <errno.h>

如需相容性詳細資訊,請參閱相容性

程式庫: 僅限偵錯版的 C 執行階段程式庫。

另請參閱

偵錯常式
_CrtSetDbgFlag
堆積狀態報告函式
_CrtReportBlockType