Heim  >  Artikel  >  Java  >  Was ist der Unterschied zwischen Stack und Queue in Java?

Was ist der Unterschied zwischen Stack und Queue in Java?

青灯夜游
青灯夜游Original
2019-11-16 16:34:003070Durchsuche

Was ist der Unterschied zwischen Stack und Queue in Java?

Warteschlange: Es handelt sich um eine lineare Tabelle, die das Einfügen auf ein Ende der Tabelle und das Löschen auf das andere Ende beschränkt.

Stapel: Ja. Eine lineare Tabelle, die das Einfügen beschränkt und Löschvorgänge nur an einem Ende der Tabelle.

Die Unterschiede sind wie folgt:

1. Unterschiedliche Regeln

1. Warteschlange: First In First Out (First In First Out) FIFO

2. Stapel: First In Last Out (First In Last Out) FILO

2. Unterschiedliche Einschränkungen für Einfüge- und Löschvorgänge

1 an einem Ende der Tabelle. Und am anderen Ende der Tabelle löschen.

2. Stapeln: Sie können nur an einem Ende der Tabelle einfügen und löschen.

3. Unterschiedliche Datendurchlaufgeschwindigkeiten

1. Warteschlange: Durchquerung basierend auf dem Adresszeiger, kann vom Kopf oder Ende aus durchlaufen werden, kann jedoch nicht gleichzeitig durchlaufen werden Es muss Platz geschaffen werden, da die Datenstruktur beim Durchlaufen nicht beeinträchtigt wird, daher sollte die Durchlaufgeschwindigkeit hoch sein.

2. Stapel: Daten können nur von oben entnommen werden Das erste, was in den unteren Teil des Stapels gelangt, muss den gesamten Stapel durchlaufen, um herausgenommen zu werden. Beim Durchlaufen der Daten muss temporärer Speicherplatz für die Daten geöffnet werden, um die Konsistenz der Daten vor dem Durchlaufen aufrechtzuerhalten.

4. Ähnlichkeiten und Unterschiede in der Schnittstellenimplementierung

Warteschlange und Stack werden durch die Collection-Schnittstelle implementiert, Warteschlange wird durch die Queue-Schnittstelle implementiert und Stack wird durch die List-Schnittstelle implementiert.

5. Ähnlichkeiten und Unterschiede in der Datendurchlaufgeschwindigkeit

Der Stapel kann nur Daten vom Kopf aufnehmen, das heißt, das erste eingegebene Ding muss den gesamten Stapel durchlaufen, bevor es entnommen werden kann Beim Durchlaufen der Daten ist es außerdem erforderlich, temporären Speicherplatz für die Daten zu öffnen, um die Konsistenz der Daten vor und nach dem Durchlaufen aufrechtzuerhalten.

Die Warteschlange wird basierend auf dem Adresszeiger durchlaufen und kann vom Anfang oder Ende aus durchlaufen werden, ohne temporären Speicherplatz zu öffnen, was viel schneller ist.

Das obige ist der detaillierte Inhalt vonWas ist der Unterschied zwischen Stack und Queue in Java?. 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