共用方式為


_CrtSetDebugFillThreshold

擷取或修改在偵錯功能的臨界值控制緩衝區填滿行為。

size_t _CrtSetDebugFillThreshold(
   size_t _NewThreshold
);

參數

  • newThreshold
    新的臨界值。

傳回值

先前臨界值。

備註

陣列的偵錯版本安全性增強的 CRT 函式用特性 (0xFD) 填滿緩衝區傳遞給它們。 這有助於發現無效的大小傳遞至函式的情況。 可惜的是,它也會降低效能。 為了改善效能,大於臨界值使用 _CrtSetDebugFillThreshold 以停用緩衝區的緩衝區填滿。 臨界值 0 會停用該緩衝區。

預設臨界值為 SIZE_T_MAX

以下是被影響函式的清單:

需求

常式

必要的標頭

_CrtSetDebugFillThreshold

<crtdbg.h>

如需更多關於相容性的資訊,請參閱入門介紹中的 相容性 (Compatibility)

程式庫

C run-time libraries 版本的偵錯

範例

// crt_crtsetdebugfillthreshold.cpp
// compile with: /MTd
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <crtdbg.h>

void Clear( char buff[], size_t size )
{
   for( int i=0; i<size; ++i )
      buff[i] = 0;
}

void Print( char buff[], size_t size )
{
   for( int i=0; i<size; ++i )
      printf( "%02x  %c\n", (unsigned char)buff[i], buff[i] );
}

int main( void )
{
   char buff[10];

   printf( "With buffer-filling on:\n" );
   strcpy_s( buff, _countof(buff), "howdy" );
   Print( buff, _countof(buff) );

   _CrtSetDebugFillThreshold( 0 );

   printf( "With buffer-filling off:\n" );
   Clear( buff, _countof(buff) );
   strcpy_s( buff, _countof(buff), "howdy" );
   Print( buff, _countof(buff) );
}

With buffer-filling on:
68  h
6f  o
77  w
64  d
79  y
00
fd  ²
fd  ²
fd  ²
fd  ²
With buffer-filling off:
68  h
6f  o
77  w
64  d
79  y
00
00
00
00
00

.NET Framework 對等用法

不適用。若要呼叫標準 C 函式,請使用 PInvoke。如需詳細資訊,請參閱平台叫用範例

請參閱

參考

偵錯常式