Delen via


Fout: calloc-overflow

Adres opschoningsfout: calloc-overflow

Opmerkingen

De functie calloc CRT maakt een matrix in het geheugen met elementen die zijn geïnitialiseerd tot 0. De argumenten kunnen een interne fout maken die leidt tot een NULL-aanwijzer als de retourwaarde.

Voorbeeld

// example1.cpp
// calloc-overflow error
#include <stdio.h>
#include <stdlib.h>

int number = -1;
int element_size = 1000;

int main() {

    void *p = calloc(number, element_size);      // Boom!

    printf("calloc returned: %zu\n", (size_t)p);

    return 0;
}

Als u dit voorbeeld wilt bouwen en testen, voert u deze opdrachten uit in een Opdrachtprompt voor ontwikkelaars van Visual Studio 2019 versie 16.9 of hoger:

cl example1.cpp /fsanitize=address /Zi
devenv /debugexe example1.exe

Resulterende fout

Schermopname van foutopsporingsprogramma met calloc-overflow-fout in voorbeeld 1.

Zie ook

Overzicht van AddressSanitizer
AddressSanitizer bekende problemen
AddressSanitizer-build- en taalreferenties
naslaginformatie over AddressSanitizer-runtime
addressSanitizer schaduwbytes
AddressSanitizer-cloud of gedistribueerde tests
integratie van AddressSanitizer-foutopsporingsprogramma's
voorbeelden van AddressSanitizer-fouten