Beim Einsatz von std::thread zur Verbesserung der Anwendungsleistung ist es wichtig zu verstehen der Unterschied zwischen dem Aufruf von detach() und dem Nichtaufruf.
Ohne detach() aufzurufen, arbeitet der erstellte Thread unabhängig innerhalb seines eigenen Ausführungspfads. In diesem Szenario:
void Someclass::Somefunction() { //... std::thread t([ ] { printf("thread called without detach"); }); //some code here }
Der Hauptthread führt „hier etwas Code“ aus, während der neu erstellte Thread „Thread aufgerufen ohne Detach“ ausgibt.
Der Aufruf von detach() ändert die Art und Weise, wie der Thread mit dem Haupt-Thread interagiert:
void Someclass::Somefunction() { //... std::thread t([ ] { printf("thread called with detach"); }); t.detach(); //some code here }
Jetzt führt der Haupt-Thread „some Code hier einfügen“ direkt nach dem Start des Threads. Wichtig ist, dass detach() nicht darauf wartet, dass der Thread abgeschlossen ist.
Berücksichtigen Sie basierend auf den oben genannten Unterschieden die folgenden Richtlinien:
Verwenden Sie detach() nur, wenn:
Achtung:
Es ist wichtig zu beachten, dass beim Beenden eines Programms (d. h. beim Zurückkehren des Hauptprogramms) immer noch getrennte Threads vorhanden sind Wenn sie ausgeführt werden, wird ihr Stapel nicht abgewickelt, sodass Destruktoren möglicherweise nicht ausgeführt werden. Dies kann zu Datenkorruption und anderen unerwünschten Folgen führen.
Das obige ist der detaillierte Inhalt vonTrennen oder nicht trennen: Wann sollten Sie „std::thread::detach()' verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!