Detaillierte Beschreibung von Shallow Copy und Deep Copy in js

Detaillierte Beschreibung von Shallow Copy und Deep Copy in js

Vorwort:

Bevor wir den folgenden Artikel studieren, wollen wir kurz das Wissen über das Gedächtnis verstehen. Das Folgende ist eine kurze Einführung

1. js-Speicher

Der js-Speicher oder der Speicher der meisten Sprachen ist in Stapel und Heap unterteilt. Die Variablenwerte grundlegender Datentypen werden auf dem Stapel zugewiesen, und die Variablenwerte von Referenzdatentypen werden auf dem Heap zugewiesen. Der Stapel speichert nur die Adressen bestimmter Objekte im Heap.

2. Abtretung

Bei grundlegenden Datentypen handelt es sich bei der Zuweisungsoperation um eine Kopie, das heißt, die neuen und alten Variablen beeinflussen sich nicht gegenseitig.

var a = 1;
var b = a;
b = 2;
console.log(b); // 2


Bei Referenzdatentypen fügt die Zuweisungsoperation einfach eine Variable im Stapel hinzu, die auf das Objekt im Heap zeigt, d. h. sie kopiert die Referenzadresse. Die neuen und alten Variablen beeinflussen sich gegenseitig. Das heißt, wenn der Objektwert der neuen Variablen geändert wird, ändert sich auch der entsprechende Wert der alten Variablen.

var a = {
    Name: "Mike"
};
var b = a;
b.name = "Buchse";
konsole.log(a); // {name: "jack"}

3. Oberflächliche Kopie

Bei grundlegenden Datentypen und Daten ohne verschachtelte Objekte sind alle Vorgänge Kopiervorgänge und die neuen und alten Variablen beeinflussen sich nicht gegenseitig.

var a = {
    Name: "Mike"
};
var b = {};
b.name = a.name;
b.name = "Buchse";
console.log(a) // {name: "mike"}

Bei Daten mit verschachtelten Objekten kopiert eine oberflächliche Kopie jedoch nur die Objekte der ersten Ebene, und die Werte auf tieferen Ebenen sind weiterhin kopierte Referenzadressen.

var a = {
    Name: "Mike",
    Sprache:
        zuerst: "Englisch",
        zweitens: "chinesisch"
    }
};
var b = {};
b.name = a.name;
b.name = "Buchse";
b.Sprache = a.Sprache;
b.language.first = "Japanisch"
console.log(a) // { Sprache: {erste: "Japanisch", zweite: "Chinesisch"}}

js implementiert Shallow Copy. Die Idee ist : Durchlaufe jedes Attribut des target und weise den Attributnamen und -wert der neuen Variable zu.
Wenn Sie die Bedeutung der Zuweisung verstehen, wird in der vierten Codezeile, wenn der Wert von target[key] ein Objekt ist, die neue Variable durch Zuweisung zugewiesen, wodurch im Wesentlichen die Adresse des Referenzdatentyps im Heap kopiert wird. Es ist nicht schwer zu verstehen, warum eine flache Kopie unterschiedliche Ergebnisse liefert, je nachdem, ob es sich um ein verschachteltes Objekt handelt oder nicht.

Funktion flachKopie(Ziel) {
    lass Ergebnis = {};
    für (const key in target) {
        Ergebnis[Schlüssel] = Ziel[Schlüssel];
    }
    Ergebnis zurückgeben;
}

4. Tiefe Kopie

Eine tiefe Kopie ist eine vollständige Kopie und die neuen und alten Variablen beeinflussen sich nicht gegenseitig.
Es gibt unterschiedliche Verarbeitungsmethoden, je nachdem, ob der Parameter ein Objekt ist. Wenn es ein Objekt ist, wird jedes Attribut und jeder Wert des Objekts zugewiesen und dann rekursiv verarbeitet; andernfalls wird es direkt zurückgegeben.

Funktion Klon(Ziel) {
    wenn (Typ des Ziels === "Objekt") {
        //Beurteilen, ob es ein Array ist let result = Array.isArray(target)? [] : {};
        für (const key in target) {
            Ergebnis[Schlüssel] = Klon(Ziel[Schlüssel]);
        }
        Ergebnis zurückgeben;
    } anders {
        Rücklaufziel;
    }
}

Dies ist das Ende dieses ausführlichen Artikels über Shallow Copy und Deep Copy von Zuweisungen in js. Weitere relevante Inhalte über Shallow Copy und Deep Copy von Zuweisungen in js finden Sie in früheren Artikeln auf 123WORDPRESS.COM oder in den verwandten Artikeln weiter unten. Ich hoffe, Sie werden 123WORDPRESS.COM auch in Zukunft unterstützen!

Das könnte Sie auch interessieren:
  • Zusammenfassung der allgemeinen Verwendung der Destrukturierungszuweisung von Javascript unter ES6
  • Ein Artikel, der Ihnen dabei hilft, die Destrukturierungszuweisung in JavaScript zu verstehen
  • Ein praktischer Leitfaden zur Destrukturierungszuweisung in JavaScript
  • Detaillierte Erklärung der Destrukturierungszuweisung in JavaScript
  • JS ES: Neue Funktion zur variablen Entkopplungszuweisung
  • 5 gängige Szenarien und Beispiele für die Destrukturierungszuweisung in JavaScript
  • Detaillierte Erläuterung der Destrukturierungszuweisung von JS ES6-Variablen
  • JavaScript-Zuweisung, der Unterschied zwischen Shallow Copy und Deep Copy

<<:  UDP DUP-Timeout UPD-Portstatus-Erkennungscodebeispiel

>>:  Wie die MySQL Select-Anweisung ausgeführt wird

Artikel empfehlen

Lösung zum Vergessen des Passworts des Pagodenpanels in Linux 3.X/4.x/5.x

Geben Sie ssh ein und geben Sie den folgenden Bef...

Grafisches Tutorial zur Installation und Konfiguration von Win32 MySQL 5.7.27

Das Installationstutorial für MySQL 5.7.27 wird w...

Eine Zeile CSS-Code zur Integration von Avatar und Nationalflagge

Es ist Nationalfeiertag und jeder kann es kaum er...

Acht Beispiele, wie Vue Komponentenkommunikation implementiert

Inhaltsverzeichnis 1. Props übergeordnete Kompone...

So ändern Sie die CentOS-Serverzeit auf die Peking-Zeit

1. Ich habe ein VPS- und CentOS-System gekauft un...

Grafisches Tutorial zur Installation von MySQL 8.0.12

MySQL8.0.12-Installationstutorial, mit allen teil...

Fallstricke und Lösungen für das Upgrade von MySQL 5.7.23 in CentOS 7

Vorwort Kürzlich bin ich beim Upgrade von MySQL 5...

Virtual Box-Tutorialdiagramm zum Duplizieren virtueller Maschinen

Nachdem man sich an VM gewöhnt hat, ist der Wechs...

So verwenden Sie MQTT im Uniapp-Projekt

Inhaltsverzeichnis 1. Referenz-Plugins im Uniapp ...