Dieser Artikel befasst sich mit der Frage, warum das einfache Einbinden des Die bereitgestellten Code-Snippet ist ein einfaches „Hallo Welt“-Programm, das den Das Ausführen dieses Programms über Valgrind mit aktivierter Leckprüfung und Nachverfolgung von Ursprüngen zeigt die folgende Ausgabe an: Dies zeigt an, dass noch 72.704 Bytes vorhanden sind erreichbar, obwohl im Programm nicht explizit Speicher zugewiesen wird. Auch wenn die Warnung von Valgrind besorgniserregend sein mag, ist es wichtig zu verstehen, dass dies ein häufiges Verhalten bei C-Programmen ist. Viele Implementierungen der C-Standardbibliothek verwenden eigene Speicherpool-Zuweiser, die Speicher für zerstörte Objekte bündeln und diese später wiederverwenden. Diese optimierte Speicherverwaltungstechnik reduziert den Speicheraufwand und verbessert die Leistung. Da Valgrind jedoch davon ausgeht, dass der gesamte zugewiesene Speicher bei Programmbeendigung an das Betriebssystem zurückgegeben werden sollte, meldet es den von diesen Pools gehaltenen Speicher als immer noch erreichbar. Dies ist nicht unbedingt ein Fehler im Programm oder in Valgrind, sondern eher ein Unterschied in den Erwartungen. Wenn Sie die weiterhin erreichbaren Warnungen mit Valgrind beseitigen möchten, können Sie dies tun Deaktivieren Sie die STL-Speicherpools (Standard Template Library), indem Sie die Compilereinstellungen ändern. Hier sind einige Methoden: Mit den GCC-Versionen 2.91 bis 3.1 können Sie das Programm mit -D__USE_MALLOC kompilieren, um die STL zu zwingen, malloc zu verwenden und Speicher sofort freizugeben. Diese Option wurde jedoch in GCC 3.3 und höher entfernt. Für GCC-Versionen 3.2.2 und höher können Sie die Umgebungsvariable GLIBCPP_FORCE_NEW festlegen, bevor Sie das Programm ausführen. Für GCC 3.4 und höher lautet der Name der Umgebungsvariablen GLIBCXX_FORCE_NEW. Bei neueren Compilern können Sie das Flag -fno-optimize-sibling-calls verwenden, um Geschwisteraufrufe zu deaktivieren Optimierung, die den STL-Speicherpool umfasst Optimierung. Einschließlich der Das obige ist der detaillierte Inhalt vonWarum führt die Einbindung von „' in C zu Valgrinds „Immer noch erreichbar'-Warnungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!Das Programm und die Valgrind-Ausgabe:
#include <iostream>
int main() {
return 0;
}
==27671== Memcheck, a memory error detector
... (output truncated)
...
==27671== 72,704 bytes in 1 blocks are still reachable in loss record 1 of 1
==27671== at 0x4C2AB9D: malloc (vg_replace_malloc.c:296)
==27671== by 0x4EC060F: ??? (in /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21)
... (output truncated)
Valgrind's Verhalten:
Deaktivieren der C-Bibliotheksoptimierung:
Verwendung von __USE_MALLOC:
Verwendung von Umgebungsvariablen:
Compiler-Flags verwenden:
Fazit: