Udostępnij za pośrednictwem


_CrtSetBreakAlloc

Ustawia punkt przerwania na określony obiekt numer kolejności alokacji (tylko w wersji debugowania).

long _CrtSetBreakAlloc(     long lBreakAlloc   );

Parametry

  • lBreakAlloc
    Numer zamówienia alokacji, dla których należy ustawić punkt przerwania.

Wartość zwracana

Zwraca poprzedni obiekt alokacji kolejność mająca Ustaw punkt przerwania.

Uwagi

_CrtSetBreakAllocumożliwia aplikacji do wykonania wykrywania przecieków pamięci podziału w określonym miejscu alokacji pamięci i śledzenie powrót do początku żądania.Funkcja używa numer kolejny obiekt alokacji zlecenia przypisane do bloku pamięci, gdy został przydzielony w stosie.Gdy _DEBUG nie jest zdefiniowany, wywołania _CrtSetBreakAlloc są usuwane podczas przetwarzania wstępnego.

Numer porządkowy alokacji obiektu jest przechowywany w lRequest zakres _CrtMemBlockHeader struktury zdefiniowane w Crtdbg.h.Gdy informacje o bloku pamięci jest zgłaszany przez jedną z funkcji zrzutu debugowania, ten numer jest ujęty w nawiasy, takich jak 36}.

Aby uzyskać więcej informacji o sposobie _CrtSetBreakAlloc mogą być używane z innych funkcji zarządzania pamięci, zobacz śledzenia stosu żądań alokacji.Aby uzyskać więcej informacji dotyczących sposobu bloków pamięci są przydzielone, został zainicjowany i zarządzanych w wersji podstawowej stosu debugowania, zobacz Szczegóły dotyczące stosu debugowania CRT.

Wymagania

Procedura

Wymagany nagłówek

_CrtSetBreakAlloc

< crtdbg.h >

Aby uzyskać więcej informacji o zgodności, zobacz zgodności we wprowadzeniu.

Biblioteki

Debugowanie wersje C biblioteki czasu wykonywania tylko.

Przykład

// crt_setbrkal.c
// compile with: -D_DEBUG /MTd -Od -Zi -W3 /c /link -verbose:lib -debug

/*
 * In this program, a call is made to the _CrtSetBreakAlloc routine
 * to verify that the debugger halts program execution when it reaches
 * a specified allocation number.
 */

#include <malloc.h>
#include <crtdbg.h>

int main( )
{
        long allocReqNum;
        char *my_pointer;

        /* 
         * Allocate "my_pointer" for the first
         * time and ensure that it gets allocated correctly
         */
        my_pointer = malloc(10);
        _CrtIsMemoryBlock(my_pointer, 10, &allocReqNum, NULL, NULL);

        /* 
         * Set a breakpoint on the allocation request
         * number for "my_pointer"
         */
        _CrtSetBreakAlloc(allocReqNum+2);

        /* 
         * Alternate freeing and reallocating "my_pointer"
         * to verify that the debugger halts program execution
         * when it reaches the allocation request
         */
        free(my_pointer);
        my_pointer = malloc(10);
        free(my_pointer);
        my_pointer = malloc(10);
        free(my_pointer);
}

Odpowiednik w programie .NET Framework

Nie dotyczy. Aby wywołać standardową funkcję C, należy użyć PInvoke. Aby uzyskać więcej informacji, zobacz przykłady wywołania platformy.

Zobacz też

Informacje

Procedury debugowania