Inhaltsverzeichnis
Frageninhalt
Lösung
Heim Backend-Entwicklung Golang Wie konvertiere ich einen bekannten Typ in einen Zeiger auf einen Typparameter in einem Schalter?

Wie konvertiere ich einen bekannten Typ in einen Zeiger auf einen Typparameter in einem Schalter?

Feb 09, 2024 am 11:30 AM
编译错误

Wie konvertiere ich einen bekannten Typ in einen Zeiger auf einen Typparameter in einem Schalter?

Der PHP-Editor Banana zeigt Ihnen, wie Sie einen bekannten Typ in einen Zeiger auf den Typparameter im Schalter umwandeln. Beim Programmieren müssen wir manchmal eine Variable eines bekannten Typs in einen Zeiger umwandeln, um flexiblere Operationen im Programm zu ermöglichen. Diese Konvertierung kann mithilfe des Operators „&“ erreicht werden. Stellen Sie dem Variablennamen den Operator „&“ voran, um ihn in einen Zeiger auf die Variable umzuwandeln. Auf diese Weise können wir Zeiger im Programm verwenden, um Variablen zu manipulieren, anstatt sie nur zuzuweisen oder zu lesen. Als nächstes werden wir detailliert vorstellen, wie diese Typkonvertierung durchgeführt wird, und Beispielcode bereitstellen, damit jeder es besser versteht.

Frageninhalt

Ich versuche, eine Funktion zu schreiben, die das Byte-Array eines JSON-Strings basierend auf dem Typparameter des Rückgabewerts umwandelt. Die Regeln lauten wie folgt:

  • map[string]interface{}: konvertiert in map[string]interface{}
  • []Byte: Keine Konvertierung, Rückgabe unverändert
  • Struktur: In Struktur konvertieren

Mein Code lautet wie folgt:

func getjsondata[t any](jsonbytearray []byte) (result *t, err error) {
    var buff t

    switch any(result).(type) { // https://appliedgo.com/blog/a-tip-and-a-trick-when-working-with-generics
    case *[]byte:
        result = &t(jsonbytearray)
    default:
        err = json.unmarshal(jsonbytearray, &buff)
        result = &buff
    }

    return
}
Nach dem Login kopieren

Dieser Code verursacht einen Typfehler beim Konvertieren des Typs von jsonbytearray in t, wie unten gezeigt:

cannot convert jsonByteArray (variable of type []byte) to type T
Nach dem Login kopieren

Wie ordne ich den Zeiger dieser Variablen vom Typ []Byte dem Rückgabewert des generischen Typs zu?

Lösung

Aufgrund t受到any的约束,所以不能直接转换。您必须断言 &jsonbytearray 实际上与该开关情况下的 *t desselben Typs:

func getjsondata[t any](jsonbytearray []byte) (result *t, err error) {
    var buff t

    switch any(result).(type) {
    case *[]byte:
        result = any(&jsonbytearray).(*t)
    default:
        err = json.unmarshal(jsonbytearray, &buff)
        result = &buff
    }

    return
}
Nach dem Login kopieren

Dadurch verschwinden die Kompilierungsfehler, aber das Design ist nicht besonders gut. Wenn Sie json.unmarshal 专门用于一种类型 (*[]byte) verwenden müssen, ist es besser, die Aufrufseite zu ändern, anstatt eine generische Funktion zu verwenden.

Ich gehe davon aus, dass Ihr Ziel darin besteht, dem Anrufer zu ermöglichen, einen Teil der Bytes so zu erhalten, wie er ist, und nicht durch Unmarshalling. Dann können Sie auf der Aufrufseite die Funktion als

aufrufen
data := GetJsonData[[]byte](jsonByteArray)
Nach dem Login kopieren

Das bedeutet, dass Sie zu diesem Zeitpunkt bereits wissen jsonbytearray es sich um ein Byte-Slice handelt.

Dann gibt es keinen Grund, diese Funktion aufzurufen. Sie können einfach die Adresse des Parameters abrufen: data := &jsonbytearray ,并在其他地方使用 json.unmarshal .

Das obige ist der detaillierte Inhalt vonWie konvertiere ich einen bekannten Typ in einen Zeiger auf einen Typparameter in einem Schalter?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So führen Sie die C-Sprache in Notepad++ aus So führen Sie die C-Sprache in Notepad++ aus Apr 08, 2024 am 10:06 AM

Notepad++ selbst kann keine C-Sprachprogramme ausführen und erfordert einen externen Compiler zum Kompilieren und Ausführen des Codes. Um einen externen Compiler zu verwenden, können Sie die folgenden Schritte ausführen: 1. Laden Sie den C-Sprachcompiler herunter und installieren Sie ihn. 2. Erstellen Sie ein benutzerdefiniertes Tool in Notepad++ und konfigurieren Sie den Pfad und die Parameter der ausführbaren Compilerdatei das C-Sprachprogramm und speichern Sie es mit der Dateierweiterung .c. 4. Wählen Sie die C-Sprachprogrammdatei aus und wählen Sie ein benutzerdefiniertes Tool zum Kompilieren aus. 5. Sehen Sie sich die Kompilierungsergebnisse an und geben Sie eine Kompilierungsfehler- oder Erfolgsmeldung aus . Bei erfolgreicher Kompilierung wird eine ausführbare Datei generiert.

Detaillierte Erläuterung der C++-Funktionsvererbung: Wie werden „Basisklassenzeiger' und „abgeleitete Klassenzeiger' bei der Vererbung verwendet? Detaillierte Erläuterung der C++-Funktionsvererbung: Wie werden „Basisklassenzeiger' und „abgeleitete Klassenzeiger' bei der Vererbung verwendet? May 01, 2024 pm 10:27 PM

Verwenden Sie bei der Funktionsvererbung „Basisklassenzeiger“ und „abgeleitete Klassenzeiger“, um den Vererbungsmechanismus zu verstehen: Wenn der Basisklassenzeiger auf das abgeleitete Klassenobjekt zeigt, wird eine Aufwärtstransformation durchgeführt und nur auf die Mitglieder der Basisklasse zugegriffen. Wenn ein abgeleiteter Klassenzeiger auf ein Basisklassenobjekt zeigt, wird eine Abwärtsumwandlung durchgeführt (unsicher) und muss mit Vorsicht verwendet werden.

Welche Taste Sie drücken müssen, wenn Sie Python-Code in Sublime ausführen Welche Taste Sie drücken müssen, wenn Sie Python-Code in Sublime ausführen Apr 03, 2024 pm 03:54 PM

Die Tastenkombinationen zum Ausführen von Python-Code in Sublime Text sind: Windows und Linux: Strg + B Mac: Befehl + B Platzieren Sie den Cursor im Code. Drücken Sie die Tastenkombination. Der Code wird mit dem standardmäßigen Python-Interpreter des Systems ausgeführt.

Was bedeutet val in Java? Was bedeutet val in Java? Apr 25, 2024 pm 10:06 PM

Das Schlüsselwort val wird in Java verwendet, um eine unveränderliche lokale Variable zu deklarieren, d. h. ihr Wert kann nach der Zuweisung nicht mehr geändert werden. Zu den Merkmalen gehören: Unveränderlichkeit: Nach der Initialisierung kann die Variable val nicht neu zugewiesen werden. Lokaler Geltungsbereich: Val-Variablen sind nur innerhalb des Codeblocks sichtbar, in dem sie deklariert sind. Typinferenz: Der Java-Compiler leitet den Typ der val-Variablen basierend auf dem zugewiesenen Ausdruck ab. Nur lokale Variablen: val kann nur zum Deklarieren lokaler Variablen verwendet werden, nicht für Klassenfelder oder Methodenparameter.

Der Unterschied zwischen const und static in C++ Der Unterschied zwischen const und static in C++ May 01, 2024 am 10:54 AM

Der Modifikator const gibt eine Konstante an und der Wert kann nicht geändert werden. Der Modifikator static gibt die Lebensdauer und den Gültigkeitsbereich der Variablen an. Durch const geänderte Datenelemente können nach der Initialisierung nicht geändert werden. Durch static geänderte Variablen werden beim Programmstart initialisiert und beim Programmende zerstört. Sie sind auch dann vorhanden, wenn kein aktives Objekt vorhanden ist, und es kann funktionsübergreifend darauf zugegriffen werden. Durch const geänderte lokale Variablen müssen bei der Deklaration initialisiert werden, während durch static geänderte lokale Variablen später initialisiert werden können. Mit Const geänderte Klassenmitgliedsvariablen müssen im Konstruktor oder in der Initialisierungsliste initialisiert werden, und statisch geänderte Klassenmitgliedsvariablen können außerhalb der Klasse initialisiert werden.

Was bedeutet = in Java? Was bedeutet = in Java? Apr 26, 2024 pm 11:30 PM

Der „="-Operator in der Programmiersprache Java wird verwendet, um einer Variablen einen Wert zuzuweisen und den Wert auf der rechten Seite des Ausdrucks in der Variablen auf der linken Seite zu speichern. Verwendung: Variable = Ausdruck, wobei Variable der Name der Variablen ist, die die Zuweisung erhält, und Ausdruck das Codesegment ist, das den Wert berechnet oder zurückgibt.

Wie unterscheidet der Compiler im Java-Funktionsüberladungsmechanismus zwischen Parametern mit demselben Stil, aber unterschiedlichen Typen? Wie unterscheidet der Compiler im Java-Funktionsüberladungsmechanismus zwischen Parametern mit demselben Stil, aber unterschiedlichen Typen? Apr 25, 2024 am 10:03 AM

Die Art und Weise, wie der Compiler zwischen überladenen Funktionen unterscheidet: anhand ihrer Signatur, die dem Typ jedes Funktionsparameters entspricht. Selbst wenn der Funktionsname und die Anzahl der Parameter gleich sind, kann der Compiler den Unterschied erkennen, solange die Parametertypen unterschiedlich sind.

So verwenden Sie die Min-Funktion in C++ So verwenden Sie die Min-Funktion in C++ May 06, 2024 pm 05:18 PM

Die Funktion min() in C++ gibt das Minimum von zwei oder mehr Werten zurück. Es handelt sich um eine generische Funktion, die Werte unterschiedlichen Typs vergleichen kann. Die Verwendung ist wie folgt: Vergleichen Sie zwei Werte: min(a, b) Vergleichen Sie mehrere Werte: min(a, b, c) Vergleichen Sie Werte verschiedener Typen: min(a, b, c) (Der Typ muss explizit angegeben werden ) Gilt für den Vergleich von Elementen in Arrays und Containern

See all articles