Fehler: strncat-param-overlap

Adressbereinigungsfehler: strncat-param-overlap

Code, der Speicher im überlappenden Puffer verschiebt, kann zu schwer zu diagnostizierenden Fehlern führen.

Beispiel

In diesem Beispiel wird gezeigt, wie AddressSanitizer Fehler erfassen kann, die durch überlappende Parameter für CRT-Funktionen verursacht werden.

(Basierend auf llvm-project/compiler-rt/test/asan/TestCases/strncat-overlap.cpp.)

// example1.cpp
// strncat-param-overlap error
#include <string.h>

void bad_function() {
    char buffer[] = "hello\0XXX";
    strncat(buffer, buffer + 1, 3); // BOOM
    return;
}

int main(int argc, char **argv) {
    bad_function();
    return 0;
}

Führen Sie zum Erstellen und Testen dieses Beispiels die folgenden Befehle in einer Visual Studio 2019,16.9- oder höher-Entwickler-Eingabeaufforderung aus:

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

Resultierender Fehler

Screenshot des Debuggers, der den Strncat-param-overlap-Fehler in Beispiel 1 anzeigt.

Siehe auch

AddressSanitizer -Übersicht
Beheben bekannter Probleme mit demSanitizer
AddressSanitizer Build- und Sprachreferenz
AddressSanitizer-Laufzeitreferenz
AddressSanitizer-Schattenbytes
AddressSanitizer-Cloud oder verteilte Tests
AddressSanitizer Debugger-Integration
Beispiele für AddressSanitizer-Fehler