Heim >Backend-Entwicklung >PHP-Tutorial >Warum konvertiert „json_encode' von PHP Sparse-Arrays in JSON-Objekte?

Warum konvertiert „json_encode' von PHP Sparse-Arrays in JSON-Objekte?

Barbara Streisand
Barbara StreisandOriginal
2024-11-27 08:50:10509Durchsuche

Why Does PHP's `json_encode` Convert Sparse Arrays to JSON Objects?

json_encode kodiert spärliche Arrays als JSON-Objekte

Bei der JSON-Kodierung von spärlichen Arrays (d. h. Arrays mit fehlenden Indizes) wird die json_encode-Funktion von PHP angezeigt unerwartetes Verhalten, Konvertierung des Arrays in ein JSON-Objekt statt in ein Array. Um dieses Verhalten zu verstehen, untersuchen wir ein Beispiel:

$a = array(
    new stdClass,
    new stdClass,
    new stdClass
);
$a[0]->abc = '123';
$a[1]->jkl = '234';
$a[2]->nmo = '567';

printf("%s\n", json_encode($a));
unset($a[1]);
printf("%s\n", json_encode($a));

Ausgabe:

[{
    "abc": "123"
},{
    "jkl": "234"
},{
    "nmo": "567"
}]
{
    "0": {
        "abc": "123"
    },
    "2": {
        "nmo": "567"
    }
}

In der anfänglichen Codierung erzeugt json_encode ein Array von Objekten, da das Sparse-Array als Objekt gültig ist . Nach dem Entfernen eines Index (1) mit unset kann das resultierende Array jedoch nicht als Array codiert werden, da es jetzt eine Lücke aufweist.

Um dieses Problem zu beheben und sicherzustellen, dass das Array weiterhin als Array codiert bleibt, verwenden Sie array_values ($a) vor dem Codieren:

printf("%s\n", json_encode(array_values($a)));
[{
    "abc": "123"
},{
    "nmo": "567"
}]

Durch die Neuindizierung des Arrays mit array_values ​​werden alle Lücken entfernt, sodass json_encode erfolgreich ausgeführt werden kann Erzeugen Sie ein gültiges JSON-Array.

Das obige ist der detaillierte Inhalt vonWarum konvertiert „json_encode' von PHP Sparse-Arrays in JSON-Objekte?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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