_CrtSetDebugFillThreshold

デバッグ関数でバッファーへの格納動作を制御するしきい値を取得または変更します。

構文

size_t _CrtSetDebugFillThreshold( size_t newThreshold );

パラメーター

newThreshold
新しいしきい値のサイズ (バイト単位)。

戻り値

前のしきい値。

解説

セキュリティが強化された CRT 関数のデバッグ バージョンでは、それに渡されたバッファーを特殊文字 (0xFE) で埋めます。 この充填文字により、関数に不適切なサイズが渡された場合に、それを見つけることができます。 残念ながら、パフォーマンスを低下させます。 パフォーマンスを向上させるには、 _CrtSetDebugFillThreshold しきい値より大きいバッファーのバッファーフィルを newThreshold 無効にします。 newThreshold値が 0 の場合、すべてのバッファーで無効になります。

既定のしきい値は SIZE_T_MAX です。

影響を受ける関数の一覧を次に示します。

必要条件

ルーチンによって返される値 必須ヘッダー
_CrtSetDebugFillThreshold <crtdbg.h>

この関数は、Microsoft 固有の関数です。 互換性の詳細については、「 Compatibility」を参照してください。

ライブラリ

C ランタイム ライブラリのデバッグ バージョンのみ。

// crt_crtsetdebugfillthreshold.c
// compile with: cl /MTd crt_crtsetdebugfillthreshold.c
#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
fe  ■
fe  ■
fe  ■
fe  ■
With buffer-filling off:
68  h
6f  o
77  w
64  d
79  y
00
00
00
00
00

関連項目

デバッグ ルーチン