_CrtSetDebugFillThreshold

Recupera ou modifica o limite de controlar o comportamento de preenchimento de buffer nas funções de depuração.

size_t _CrtSetDebugFillThreshold(
   size_t _NewThreshold
);

Parâmetros

  • newThreshold
    Limite de novo.

Valor de retorno

O limite anterior.

Comentários

As versões de depuração de algumas funções de CRT com segurança avançada preencher o buffer passado para eles com um caractere especial (0xFD).Isso ajuda a localizar casos em que o tamanho incorreto foi passado para a função.Infelizmente, ele também reduz o desempenho.Para melhorar o desempenho, use _CrtSetDebugFillThreshold para desativar o preenchimento de buffer para maior do que o limite de buffers.Um limiar de 0 desativará a ele para todos os buffers.

O limite padrão é SIZE_T_MAX.

Aqui está uma lista das funções afetadas.

Requisitos

Rotina

Cabeçalho necessário

_CrtSetDebugFillThreshold

<crtdbg.h>

Para obter mais informações de compatibilidade, consulte compatibilidade na introdução.

Bibliotecas

Versões de depuração de bibliotecas de tempo de execução c somente.

Exemplo

// 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

Equivalência do .NET Framework

Não aplicável. Para chamar a função c padrão, use PInvoke. Para obter mais informações, consulte Exemplos de invocação de plataforma.

Consulte também

Referência

Rotinas de depuração