HashMapi itereerimine Javas

Hashmapi Itereerimine Javas



Kirjete säilitamisel Java-s võib esineda juhtumeid, kus arendajal on vaja juurdepääsu konkreetsele ' HashMap ', et seda ära kasutada või maha visata. Näiteks teatud kirjete komplekti uuesti kasutamine või aegunud andmekogumi teisaldamine rämpsposti. Sellistel juhtudel aitab HashMapi itereerimine Java-s andmetele juurde pääseda ja mälu tõhusalt hallata.

Selles kirjutises käsitletakse lähenemisviise 'HashMapi' itereerimiseks Javas.

Mis on Javas HashMap?

A ' HashMap ' salvestab esemeid kujul ' võtmeväärtus ” paarid ja neid saab kutsuda mis tahes muud tüüpi indeksiga (nt String). See võimaldab salvestada ka nullklahve.







Kuidas korrata HashMapi Javas?

Java HashMapi saab itereerida, kasutades alltoodud lähenemisviise:



1. lähenemine: HashMapi kordamine Javas, kasutades silmust 'for'.

' entrySet() ” meetod annab komplektvaate kõikidest räsikaardis sisalduvatest kirjetest/elementidest. ' getKey() ” ja „ getValue() ” meetodid toovad kirjest vastavalt võtme ja väärtuse. Neid lähenemisviise saab kasutada kombineeritult, et esmalt pääseda juurde räsikaardile ja itereerida kogunenud võtmete ja väärtuste kaudu, kasutades ' jaoks 'silmus.



Süntaks





hashmakaart. kirjeSet ( )

Ülaltoodud süntaksis ' hashmakaart ' viitab ' HashMap ” klassi objekt.

Näide

Vaatame allpool toodud näidet:



importida java.util.HashMap ;

importida java.util.Map ;

avalik klass Näide {

avalik staatiline tühine peamine ( String args [ ] ) {

Kaart < Täisarv , String > custom_hashmap = uus HashMap < Täisarv , String > ( ) ;

custom_hashmap. pane ( 1 , 'Harry' ) ;

custom_hashmap. pane ( 2 , 'Taavet' ) ;

custom_hashmap. pane ( 3 , 'Sara' ) ;

jaoks ( Kaart . Sissepääs < Täisarv , String > seatud : custom_hashmap. kirjeSet ( ) ) {

Süsteem . välja . println ( seatud. getKey ( ) + ':' + seatud. getValue ( ) ) ;

} }

}

Ülaltoodud koodis:

  • Esiteks looge ' HashMap 'nimega' custom_hashmap ', nii et võti on määratud kui ' täisarv ' ja väärtus kui ' string ' on koodis esindatud kui ' Kaart ”.
  • Pärast seda seostage ' pane() ” meetod räsikaardiga, et sisestada märgitud väärtused kujul „ võtmeväärtus ” paarid.
  • Nüüd rakendage ' jaoks 'silmus koos '' entrySet() ” meetod räsikaardi läbimiseks.
  • Pange tähele, et määratud ' Kaart.Sisenemine ” liides võimaldab kasutajal töötada kaardikirjega.
  • Lõpuks rakendage ' getKey() ” ja „ getValue() ” meetodid eraldatud võtmetele ja väärtustele juurdepääsuks ning nende kuvamiseks.

Väljund

Selles väljundis saab analüüsida, et seatud võtme-väärtuse paare korratakse ja kuvatakse.

2. lähenemisviis: HashMapi kordamine Javas, kasutades meetodit „forEach()”.

' igaühele() ” meetodit kasutatakse iga elemendi jaoks konkreetse toimingu rakendamiseks. Seda meetodit saab rakendada, et lihtsalt itereerida läbi iga võtme-väärtuse paari ' HashMap ” ja kuvage see.

Süntaks

igaühele ( koos Super JA > x )

Ülaltoodud süntaksis võtab see meetod parameetri ' x ”, mis vastab iga elemendi puhul sooritatavale toimingule.

Näide

Järgime alltoodud koodi:

importida java.util.HashMap ;

importida java.util.Map ;

avalik klass Näide {

avalik staatiline tühine peamine ( String args [ ] ) {

Kaart < Täisarv , String > custom_hashmap = uus HashMap < Täisarv , String > ( ) ;

custom_hashmap. pane ( 1 , 'Harry' ) ;

custom_hashmap. pane ( 2 , 'Taavet' ) ;

custom_hashmap. pane ( 3 , 'Sara' ) ;

custom_hashmap. igaühele ( ( võti, väärtus ) -> Süsteem . välja . println ( võti + ':' + väärtus ) ) ;

} }

Ülaltoodud illustratsioonil:

  • Tuletage meelde arutatud lähenemisviise, et luua ' HashMap ' ja määrake väärtused kujul ' võtmeväärtus ” paarid.
  • Nüüd seostage ' igaühele() ” meetodit loodud HashMapiga ja kuvada kõik itereeritud „ võtmeväärtus ” paarid konsoolil.

Väljund

Nagu näete, on võtmed ja nende vastavad väärtused jaotises ' HashMap ” on korratud.

3. lähenemisviis: HashMapi itereerimine Javas, kasutades objekti 'Iterator'.

' Iteraator ' objekti kasutatakse elementide ükshaaval läbimiseks ja ' iteraator () ” meetodit saab kasutada iteraatori toomiseks. ' hasNext() 'meetod annab' tõsi ” kui räsikaardil on järgmine element ja „ järgmine () ” meetod annab järgmise hashmapi elemendi. Neid lähenemisviise saab kasutada kombineeritult HashMapi itereerimiseks, järgmise võtme-väärtuse paari olemasolu kontrollimiseks ja selle hankimiseks.

Süntaks

Iteraator iter = x. iteraator ( ) ;

Selles süntaksis:

  • x ” on kogumisobjekt.
  • iter ” on Iteraatori liidese tüüpi ja vastab „ x ”.

Näide

Vaatame allpool toodud näidet:

importida java.util.Iterator ;

importida java.util.Map.Entry ;

importida java.util.HashMap ;

importida java.util.Map ;

avalik klass Näide {

avalik staatiline tühine peamine ( String args [ ] ) {

Kaart < Täisarv , String > custom_hashmap = uus HashMap < Täisarv , String > ( ) ;

custom_hashmap. pane ( 1 , 'Harry' ) ;

custom_hashmap. pane ( 2 , 'Taavet' ) ;

custom_hashmap. pane ( 3 , 'Sara' ) ;

Iteraator < Sissepääs < Täisarv , String >> iter = custom_hashmap. kirjeSet ( ) . iteraator ( ) ;

samas ( iter. hasNext ( ) ) {

Kaart . Sissepääs < Täisarv , String > määrama = ( Kaart . Sissepääs < Täisarv , String > ) iter. järgmiseks ( ) ;

Süsteem . välja . println ( määrama. getKey ( ) + ':' + määrama. getValue ( ) ) ;

} } }

Ülaltoodud demonstratsioonis rakendage järgmisi samme.

  • Korrake käsitletud metoodikaid ' HashMap ja eraldades võtmeväärtus ” paarid.
  • Nüüd seostage ' Iteraator ” objekt koos loodud HashMapiga ja tsükkel läbi võtme-väärtuse paaride „ abil entrySet() ” ja „ iteraator () ” meetodid.
  • Lõpuks uurige HashMapi, kontrollides järgmist elementi rakendatud ' hasNext() ” meetod. Kui jah, kuvage järgmine element, kasutades ' järgmine () ” meetod.
  • Lisatud ' getKey() ” ja „ getValue() ” meetodid tagavad, et akumuleeritud element tuuakse kujul „ võtmeväärtus ” paar.

Väljund

Ülaltoodud väljund näitab, et iteratsioon on tehtud õigesti.

Järeldus

A ' HashMap ” salvestab üksused asukohas ” võtmeväärtus ” paarid. Seda saab itereerida ' jaoks 'silmus, ' igaühele() ' meetod või ' Iteraator ” objekt. HashMapi iteratsiooni saab teha lihtsalt, pääsedes juurde igale võtme-väärtuse paarile või viidates vastavalt järgmisele elemendile. Selles ajaveebis käsitleti lähenemisviise HashMapi itereerimiseks Javas.