Ein Go-Programm stößt beim Aufruf von http.Post() auf einen Hang während es als gemeinsam genutzte C-Bibliothek erstellt wurde (-buildmode=c-shared). Die standardmäßige ausführbare Binärdatei (GOOS=linux GOARCH=amd64 ./example) gibt jedoch den korrekten Wert zurück.
Das Problem tritt auf, weil die Go-Laufzeit geladen wird, wenn die C Die gemeinsam genutzte Bibliothek wird vom übergeordneten Prozess geladen. Wenn die Bibliothek jedoch in einem geforkten untergeordneten Prozess verwendet wird, wird die Go-Laufzeit nicht korrekt geladen, was zu unvorhersehbarem Verhalten und hängenden Aufrufen führt.
Die Lösung besteht darin, das Laden der Go-Laufzeit innerhalb des untergeordneten Elements zu steuern Verfahren. Um dies zu tun:
Durch das explizite Laden der Go-Laufzeit im untergeordneten Prozess wird sichergestellt, dass die Laufzeit korrekt initialisiert wird und Netzwerkaufrufe erfolgreich durchgeführt werden können.
Das obige ist der detaillierte Inhalt von## Warum bleibt meine Go C-Shared-Bibliothek bei Netzwerkaufrufen in einem gespaltenen untergeordneten Prozess hängen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!