1. ఇటరేటర్లు ఎలా వచ్చాయి అనే నేపథ్యం
మీకు ఇప్పటికే పరిచయం ఉంది HashSet
. మీరు ఒక పాఠాన్ని చదవడమే కాకుండా దాన్ని నిజంగా పరిశోధించి ఉంటే, మీరు ఈ ప్రశ్నను అడగాలి:
స్క్రీన్పై అన్ని HashSet మూలకాల జాబితాను నేను ఎలా ప్రదర్శించగలను? get()
అన్ని తరువాత, ఇంటర్ఫేస్ మరియు set()
పద్ధతులు లేవు !
మరియు HashSet
ఈ పరిమితిలో ఒంటరిగా కాదు. తో పాటుగా HashSet
, ఎలిమెంట్స్ను ఇండెక్స్ ద్వారా తిరిగి పొందేందుకు అనుమతించని అనేక ఇతర సేకరణలు ఉన్నాయి, ఎందుకంటే మూలకాలకు నిర్వచించబడిన క్రమం లేదు.
సంవత్సరాలుగా, ప్రోగ్రామర్లు గ్రాఫ్లు మరియు చెట్ల వంటి చాలా క్లిష్టమైన డేటా నిర్మాణాలను కనుగొన్నారు. లేదా జాబితాల జాబితాలు.
కొత్త మూలకాలు జోడించబడినప్పుడు లేదా ఇప్పటికే ఉన్న మూలకాలు తీసివేయబడినప్పుడు చాలా కంటైనర్లు వాటి మూలకాల క్రమాన్ని మారుస్తాయి. ఉదాహరణకు, జాబితా ఒక నిర్దిష్ట క్రమంలో మూలకాలను నిల్వ చేస్తుంది మరియు కొత్త మూలకం జోడించబడినప్పుడు, ఇది దాదాపు ఎల్లప్పుడూ జాబితా మధ్యలో చొప్పించబడుతుంది.
మరియు మూలకాలను నిల్వ చేసే కంటైనర్ ఉన్న పరిస్థితులను కూడా మేము పొందుతాము కానీ ఏ స్థిరమైన క్రమంలో కాదు.
ఇప్పుడు మనం అటువంటి సేకరణ నుండి అన్ని మూలకాలను శ్రేణి లేదా జాబితాలోకి కాపీ చేయాలనుకుంటున్నాము. మేము అన్ని అంశాలను పొందాలి. మూలకాలపై మనం పునరావృతమయ్యే క్రమం గురించి మేము పట్టించుకోము — ముఖ్యమైన విషయం ఏమిటంటే ఒకే మూలకాలపై ఒకటి కంటే ఎక్కువసార్లు పునరావృతం చేయకూడదు. మేము దానిని ఎలా చేస్తాము?
2. సేకరణ కోసం ఇటరేటర్
పై సమస్యకు పరిష్కారంగా ఇటరేటర్లు ప్రతిపాదించబడ్డాయి.
ఇటరేటర్ అనేది సేకరణతో అనుబంధించబడిన ఒక ప్రత్యేక వస్తువు, ఇది సేకరణలోని అన్ని అంశాలను పునరావృతం చేయకుండా ప్రయాణించడంలో సహాయపడుతుంది.
ఏదైనా సేకరణ కోసం ఇటరేటర్ని పొందడానికి మీరు క్రింది కోడ్ని ఉపయోగించవచ్చు:
Iterator<Type> it = name.iterator();
name
సేకరణ వేరియబుల్ పేరు ఎక్కడ ఉంది, Type
సేకరణ యొక్క మూలకాల రకం, iterator()
ఇది సేకరణ యొక్క పద్ధతుల్లో ఒకటి మరియు it
ఇటరేటర్ వేరియబుల్ పేరు.
ఇటరేటర్ ఆబ్జెక్ట్ 3 పద్ధతులను కలిగి ఉంటుంది:
పద్ధతి | వివరణ |
---|---|
|
సేకరణలో తదుపరి మూలకాన్ని అందిస్తుంది |
|
ఇంకా ప్రయాణించని అంశాలు ఏవైనా ఉన్నాయా అని తనిఖీ చేస్తుంది |
|
సేకరణ యొక్క ప్రస్తుత మూలకాన్ని తీసివేస్తుంది |
ఈ పద్ధతులు స్కానర్ క్లాస్ nextInt)
మరియు hasNextInt()
పద్ధతులకు కొంతవరకు సమానంగా ఉంటాయి.
ఈ next()
పద్ధతి మనకు ఇటరేటర్ని పొందిన సేకరణ యొక్క తదుపరి మూలకాన్ని అందిస్తుంది.
hasNext()
ఇటరేటర్ ఇంకా తిరిగి ఇవ్వని అదనపు అంశాలు సేకరణలో ఉన్నాయో లేదో ఈ పద్ధతి తనిఖీ చేస్తుంది.
ఒక యొక్క అన్ని అంశాలను ఎలా ప్రదర్శించాలో ఇక్కడ ఉంది HashSet
:
కోడ్ | గమనికలు |
---|---|
|
HashSet మూలకాలను నిల్వ చేసే వస్తువును సృష్టించండి String . మేము వేరియబుల్కు వివిధ భాషలలో శుభాకాంక్షలను జోడిస్తాము set . సెట్ కోసం ఇటరేటర్ వస్తువును పొందండి set . ఇంకా మూలకాలు ఉన్నంత వరకు తదుపరి మూలకాన్ని పొందండి స్క్రీన్పై మూలకాన్ని ప్రదర్శించండి |
3. For-each
లూప్
ఇటరేటర్ యొక్క ప్రధాన ప్రతికూలత ఏమిటంటే మీ కోడ్ for
లూప్ని ఉపయోగించడం కంటే మరింత గజిబిజిగా మారుతుంది.
for
పోల్చడానికి, లూప్ని ఉపయోగించి మరియు ఇటరేటర్ని ఉపయోగించి జాబితాను ప్రదర్శిస్తాము :
ఇటరేటర్ | లూప్ కోసం |
---|---|
|
|
అవును, లూప్ని ఉపయోగించి మూలకాలను దాటడం చాలా ఉత్తమం ArrayList
- ప్రతిదీ చిన్నదిగా మారుతుంది.
కానీ జావా సృష్టికర్తలు మళ్లీ మాపై కొంత చక్కెర పోయాలని నిర్ణయించుకున్నారు. అదృష్టవశాత్తూ, ఇది సింటాక్టిక్ చక్కెర .
వారు జావాకు కొత్త రకమైన లూప్ ఇచ్చారు మరియు దానిని for-each
లూప్ అని పిలిచారు. సాధారణంగా ఇది ఇలా కనిపిస్తుంది:
for(Type name:collection)
collection
సేకరణ వేరియబుల్ పేరు ఎక్కడ ఉంది, Type
ఇది సేకరణలోని మూలకాల రకం మరియు name
లూప్ యొక్క ప్రతి పునరావృతం వద్ద సేకరణ నుండి తదుపరి విలువను తీసుకునే వేరియబుల్ పేరు.
ఈ రకమైన లూప్ ఒక అవ్యక్త పునరావృత్తిని ఉపయోగించి సేకరణలోని అన్ని మూలకాల ద్వారా పునరావృతమవుతుంది. ఇది వాస్తవానికి ఈ విధంగా పనిచేస్తుంది:
ప్రతి లూప్ కోసం | కంపైలర్ ఏమి చూస్తుంది: ఇటరేటర్తో లూప్ చేయండి |
---|---|
|
|
కంపైలర్ for-each
మీ కోడ్లో లూప్ను ఎదుర్కొన్నప్పుడు, అది కేవలం కుడి వైపున ఉన్న కోడ్తో భర్తీ చేస్తుంది: ఇది ఏదైనా ఇతర తప్పిపోయిన పద్ధతి కాల్లతో పాటు ఇటరేటర్ను పొందడానికి కాల్ను జోడిస్తుంది.
ప్రోగ్రామర్లు లూప్ను ఇష్టపడతారు for-each
మరియు వారు సేకరణలోని అన్ని అంశాలని మళ్లించాల్సిన అవసరం వచ్చినప్పుడు దాదాపు ఎల్లప్పుడూ దాన్ని ఉపయోగిస్తారు.
ArrayList
లూప్ని ఉపయోగించి జాబితాపై మళ్లించడం కూడా for-each
చిన్నదిగా కనిపిస్తుంది:
ప్రతి లూప్ కోసం | లూప్ కోసం |
---|---|
|
|
for-each
4. లూప్లోని మూలకాన్ని తీసివేయడం
లూప్కు for-each
ఒక లోపం ఉంది: ఇది మూలకాలను సరిగ్గా తీసివేయదు. మీరు ఇలా కోడ్ వ్రాస్తే, మీకు ఎర్రర్ వస్తుంది.
కోడ్ | గమనిక |
---|---|
|
తొలగింపు ఆపరేషన్ లోపాన్ని సృష్టిస్తుంది! |
ఇది చాలా మంచి మరియు అర్థమయ్యే కోడ్, కానీ ఇది పని చేయదు.
మీరు సేకరణను పునరుక్తితో ప్రయాణిస్తున్నప్పుడు దాన్ని మార్చలేరు.
ఈ పరిమితిని అధిగమించడానికి మూడు మార్గాలు ఉన్నాయి.
1. వేరే రకమైన లూప్ని ఉపయోగించండి
When traversing an ArrayList collection
, మీరు కౌంటర్ వేరియబుల్తో సాధారణ లూప్ని ఉపయోగించవచ్చు i
.
కోడ్ |
---|
|
HashSet
అయితే, ఈ ఎంపిక మరియు HashMap
సేకరణలకు తగినది కాదు
2. స్పష్టమైన పునరావృత్తిని ఉపయోగించండి
మీరు ఇటరేటర్ను స్పష్టంగా ఉపయోగించవచ్చు మరియు దాని remove()
పద్ధతికి కాల్ చేయవచ్చు.
పని చేసే వెర్షన్ | పని చేయని సంస్కరణ |
---|---|
|
|
remove()
మేము ఇటరేటర్ ఆబ్జెక్ట్పై పద్ధతిని పిలుస్తాము ! ఐటెమ్ తీసివేయబడిందని పునరావృతం చేసే వ్యక్తికి తెలుసు మరియు పరిస్థితిని సరిగ్గా నిర్వహించగలడు.
3. సేకరణ కాపీని ఉపయోగించండి
మీరు సేకరణ కాపీని కూడా సృష్టించి, ఆపై కాపీని లూప్లో ఉపయోగించవచ్చు for-each
మరియు అసలు సేకరణ నుండి మూలకాలను తొలగించవచ్చు.
కోడ్ | గమనిక |
---|---|
|
సేకరణ కాపీని సృష్టించడం చాలా సులభం సేకరణ కాపీ కోసం లూప్ ఇటరేటర్ని ఉపయోగిస్తుంది. సేకరణ నుండి మూలకాలు తీసివేయబడతాయి list . |
మూలకాలు డూప్లికేట్ కానందున సేకరణ త్వరగా కాపీ చేయబడుతుంది. బదులుగా, కొత్త సేకరణ పాత సేకరణలో ఇప్పటికే ఉన్న మూలకాల సూచనలను నిల్వ చేస్తుంది.
GO TO FULL VERSION