Heim > Backend-Entwicklung > C++ > Warum führt die Einbindung von „' in C zu Valgrinds „Immer noch erreichbar'-Warnungen?

Warum führt die Einbindung von „' in C zu Valgrinds „Immer noch erreichbar'-Warnungen?

Linda Hamilton
Freigeben: 2024-12-03 18:35:13
Original
684 Leute haben es durchsucht

Why Does Including `` in C   Cause Valgrind's

Einbinden eines Standardbibliotheksheaders in C und Valgrind-Warnungen

Einführung:

Dieser Artikel befasst sich mit der Frage, warum das einfache Einbinden des

Das Programm und die Valgrind-Ausgabe:

Die bereitgestellten Code-Snippet ist ein einfaches „Hallo Welt“-Programm, das den Header, führt aber keine Zuordnungen durch:

#include <iostream>

int main() {
  return 0;
}
Nach dem Login kopieren

Das Ausführen dieses Programms über Valgrind mit aktivierter Leckprüfung und Nachverfolgung von Ursprüngen zeigt die folgende Ausgabe an:

==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)
Nach dem Login kopieren

Dies zeigt an, dass noch 72.704 Bytes vorhanden sind erreichbar, obwohl im Programm nicht explizit Speicher zugewiesen wird.

Valgrind's Verhalten:

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.

Deaktivieren der C-Bibliotheksoptimierung:

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:

Verwendung von __USE_MALLOC:

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.

Verwendung von Umgebungsvariablen:

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.

Compiler-Flags verwenden:

Bei neueren Compilern können Sie das Flag -fno-optimize-sibling-calls verwenden, um Geschwisteraufrufe zu deaktivieren Optimierung, die den STL-Speicherpool umfasst Optimierung.

Fazit:

Einschließlich der Der Header allein verursacht keine Speicherlecks, kann jedoch aufgrund der Speicherpoolverwaltung der C-Bibliothek in Valgrind immer noch erreichbare Warnungen auslösen. Dieses Verhalten ist erwartet und kein Fehler. Durch das Deaktivieren der STL-Optimierungen können diese Warnungen beseitigt werden, dies kann jedoch auf Kosten einer verringerten Leistung gehen.

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage