php-Editor Xigua führt Sie in das Slice-Index-Problem in Golang ein. In Golang ist Slice ein flexibles dynamisches Array, mit dem Daten einfach hinzugefügt, gelöscht, geändert und abgefragt werden können. Bei der Verwendung von Slice treten jedoch manchmal Probleme bei der Indizierung auf, d. h. ob der indizierte Wert eine Kopie des Werts oder eine Referenz ist. Für die korrekte Verwendung von Slice ist es entscheidend, den Unterschied zwischen dem Wert eines Index und einer Referenz zu verstehen. Als nächstes werden wir dieses Problem im Detail untersuchen, um Ihnen zu helfen, Slice besser zu verstehen und anzuwenden.
Ich lerne los und bin verwirrt über das „Zeug“, das wir durch die Slice-Indizierung erhalten.
Angenommen, wir haben eine Struktur vom Typ bag
:
type bag struct { item string }
Dann nehmen wir an, wir haben eine Gepäckliste:
itembag := []bag{ {item: "item1"}, {item: "item2"}, {item: "item3"} }
Jetzt versuche ich, den Inhalt des ersten Elements der itembag
-Variablen zu ändern. Naiverweise habe ich Folgendes getan:
item1 := itembag[0] item1.item = "not item1" fmt.printf("itembag[0].item == 'not item1'? %v", itembag[0].item == "not item1") // console print false
Die Antwort, die ich bekommen habe, ist falsch, weil (ich denke, bitte korrigieren Sie mich, wenn ich falsch liege) wenn wir das tun item1 := itembag[0]
时,我们正在复制 itembag[0]
的值并且将其分配给 item1
. Ich glaube, darum geht es in diesem Blog.
Um dies zu beweisen, habe ich versucht, den Zeiger von itembag[0]
zu ermitteln und seinen Wert zu ändern, und voilà, ich habe erreicht, was ich tun wollte:
item1 := &itembag[0] item1.item = "not item1" fmt.printf("itembag[0].item == 'not item1'? %v", itembag[0].item == "not item1") // console print true
Dies macht Sinn, wenn wir sagen, dass wir bei der Erstellung eines Slice-Index (d. h. Slice[Index]) eine Kopie seines Werts anstelle des zugrunde liegenden Elements erhalten.
Wenn ich es jetzt tue:
itemBag[0].item = "not item1" fmt.Printf("itemBag[0].item == 'not item1'? %v", itemBag[0].item == "not item1")
Das Ergebnis ist true
, was nicht das ist, was ich erwartet habe. Weil es so aussieht, als wäre true
,这不是我所期望的。 因为它看起来像 itembag[0].item
在语法上与我首先将 itembag[0]
syntaktisch dasselbe, als ob ich zuerst einer Variablen zugewiesen und dann auf das zugrunde liegende Element verwiesen hätte.
Ich habe das Gefühl, dass mir ein wesentliches Kapitel im Golang-Kurs fehlt. Bitte, jede Weiterleitung/Erklärung wäre sehr dankbar!
Ich habe versucht, etwas wie „Slice-Index als Referenz übergeben“ zu googeln, konnte aber bei Google nicht das genaue Schlüsselwort finden. LösungDie Zuweisungsoperation kopiert den Wert. Wenn Sie also Folgendes tun:
item1 = itembag[0]
itembag[0]
处创建该对象的副本,其类型为 bag
。现在 item1
Sie erstellen eine Kopie des Objekts bei mit dem Typ . Jetzt verfügt item1
über eine Kopie davon und alle Änderungen, die Sie daran vornehmen, werden an dieser Kopie vorgenommen. itempr
。当执行itempr.item="x"
时,相当于(*itempr).item=x
itemptr = &itembag[0]
zu, wodurch der Inhalt des Zeigers geändert wird. itembag[0]
ist ein adressierbarer Wert, d. h. Sie können seine Adresse abrufen.
https://www.php.cn/link/753a043674f0193523abc1bbce678686itembag[0].item
Der
ist auch ein adressierbarer Wert, Sie können ihm also etwas zuweisen und er wird im Slice selbst widergespiegelt.
Die folgenden Werte sind jedoch nicht adressierbar: m[1]
m:=map[int]bag{1:bag{item:"str"}} m[1].item="str1"
eine Kopie des Werts in der Karte zurückgibt und der ihm zugewiesene Wert verloren geht. Folgende Probleme können jedoch gelöst werden: bag
的 item
m:=map[int]*bag{1:&bag{item:"str"}} m[1].item="str1"
item
des 🎜 in der Karte festgelegt. 🎜Das obige ist der detaillierte Inhalt vonGolang Slice-Indexwert oder Referenz?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!