Maison  >  Article  >  développement back-end  >  La différence entre un tableau php et une liste chaînée

La différence entre un tableau php et une liste chaînée

王林
王林original
2019-09-19 17:57:372693parcourir

La différence entre un tableau php et une liste chaînée

La différence entre les tableaux et les listes chaînées en PHP

Du point de vue de la structure logique

1. , le tableau doit avoir une longueur fixe (nombre d'éléments) définie à l'avance, et ne peut pas s'adapter à l'augmentation ou à la diminution dynamique des données. Lorsque les données augmentent, le nombre d'éléments peut dépasser le nombre initialement défini ; lorsque les données diminuent, un gaspillage de mémoire se produit ; le tableau est directement accessible selon l'indice.

2. La liste chaînée alloue dynamiquement du stockage, qui peut s'adapter à l'augmentation et à la diminution dynamiques des données, et peut facilement insérer et supprimer des éléments de données. (Lors de l'insertion ou de la suppression d'éléments de données dans le tableau, d'autres éléments de données doivent être déplacés, ce qui est très fastidieux.) La liste chaînée doit trouver l'élément suivant en fonction du pointeur suivant.

Du point de vue du stockage mémoire

1. Les tableaux (statiques) allouent de l'espace à partir de la pile, ce qui est pratique et rapide pour les programmeurs, mais le degré de liberté est petit.

2. La liste chaînée alloue de l'espace à partir du tas, ce qui a une grande liberté mais est difficile à demander et à gérer.

Comme le montre la comparaison ci-dessus, si vous avez besoin d'accéder aux données rapidement et rarement ou sans insérer et supprimer des éléments, vous devez utiliser un tableau au contraire, si vous devez fréquemment insérer et supprimer des éléments ; , vous devez utiliser une structure de données de liste chaînée.

Supplément :

Les tableaux stockent les éléments en continu en mémoire étant donné que chaque élément occupe la même mémoire, n'importe quel élément du tableau est rapidement accessible via des indices. Mais si vous souhaitez ajouter un élément au tableau, vous devez déplacer un grand nombre d'éléments, libérer de l'espace pour un élément dans la mémoire, puis y placer l'élément à ajouter.

De même, si vous souhaitez supprimer un élément, vous devez également déplacer un grand nombre d'éléments pour remplir les éléments déplacés. Si votre application nécessite un accès rapide aux données, avec peu ou pas d'insertions et de suppressions d'éléments, vous devez utiliser des tableaux.

La liste chaînée est tout le contraire. Les éléments de la liste chaînée ne sont pas stockés séquentiellement dans la mémoire, mais sont liés entre eux via des pointeurs qui existent dans les éléments. Par exemple : l'élément précédent a un pointeur pointant vers l'élément suivant, et ainsi de suite jusqu'au dernier élément.

Si vous souhaitez accéder à un élément de la liste chaînée, vous devez commencer par le premier élément et continuer à trouver la position de l'élément requise. Mais l'ajout et la suppression d'un élément sont très simples pour la structure de données de la liste chaînée. Il suffit de modifier le pointeur dans l'élément. Si votre application nécessite une insertion et une suppression fréquentes d'éléments, vous devrez utiliser une structure de données de liste chaînée.

Tutoriel recommandé : Tutoriel vidéo PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn