Richtige Ioctl-Verwendung in Go
In Go erfolgt der ioctl()-Aufruf über die Syscall()-Funktion des unsicheren Pakets. Dies führt im Vergleich zur C-Programmierung zu einer erheblichen Komplexität der Aufgabe.
Das Go-Äquivalent des bereitgestellten C-Codes, der ioctl() für den Dateideskriptor f mit der Operation IOCTL_MBOX_PROPERTY und dem Puffer buf aufruft:
func mBoxProperty(f *os.File, buf [256]int64) { err := Ioctl(f.Fd(), IOWR(100, 0, 8), uintptr(unsafe.Pointer(&buf[0]))) if err != nil { log.Fatalln("mBoxProperty() : ", err) } }
Als solche ist Ioctl() eine Funktion, die Syscall() mit einer vordefinierten Schnittstelle umschließt, die die Aufgabe, ioctl()-Aufrufe darin durchzuführen, vereinfacht Gehen. Fehler, die während des ioctl()-Aufrufs auftreten, werden als syscall.Errno zurückgegeben.
Es ist wichtig zu verhindern, dass der Garbage Collector den Speicher freigibt, auf den buf zeigt, bevor der ioctl()-Aufruf abgeschlossen ist. Dies kann erreicht werden, indem sichergestellt wird, dass buf bis zum ioctl()-Aufruf im Gültigkeitsbereich bleibt. Dies kann erreicht werden, indem buf als lokale Variable innerhalb der Funktion deklariert wird. Alternativ kann runtime.KeepAlive(buf) verwendet werden, um zu verhindern, dass der Garbage Collector den Puffer freigibt.
In Fällen, in denen der Kernel die Übergabe eines kleinen Speicherpuffers erwartet, ist Vorsicht geboten. Der Garbage Collector gibt möglicherweise Speicherobjekte frei, von denen er glaubt, dass sie nicht verwendet werden, oder verschiebt sie sogar in den Speicher. Diese Aktionen bleiben für den Kernel unsichtbar, der den alten Zeiger behält und ihn weiterhin verwendet.
Um dieses Problem zu mildern, kann eine kleine mit cgo geschriebene C-Erweiterung verwendet werden, um über malloc() einen geeigneten Puffer zuzuweisen unterliegt nicht der Garbage Collection. Dieser Puffer kann dann an ioctl() übergeben werden. Indem der alte Zeigerwert verfolgt und nach der Verwendung freigegeben wird, können Speicherlecks vermieden werden.
Das obige ist der detaillierte Inhalt vonWie kann ich ioctl() sicher in Go ohne Speicherlecks verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!