"ஹாய், அமிகோ!"
"ஹாய், எல்லி!"
"இன்று நாங்கள் சேகரிப்புகளின் கட்டமைப்பை ஒருமுறை மற்றும் அனைவருக்கும் சுற்றி வருவோம்."
"நான் இதற்காக நீண்ட நேரம் காத்திருந்தேன்."
"சேகரிப்புகள் என்னவென்று உங்களுக்கு ஏற்கனவே தெரியும், அவற்றுடன் எவ்வாறு வேலை செய்வது என்பது உங்களுக்குத் தெரியும். உங்கள் அறிவை ஒரு கண்டிப்பான அமைப்பாக ஒழுங்கமைக்க வேண்டிய நேரம் இது. பிறகு பல 'ஏன்' மற்றும் 'எப்படி' கேள்விகள் மறைந்துவிடும், மேலும் பெரும்பாலான விஷயங்கள் தெளிவாகிவிடும்."
" சேகரிப்பு இடைமுகங்கள் . சேகரிப்பு இடைமுகங்களின் பரம்பரை அமைப்பு இது போல் தெரிகிறது:"

இரண்டு விஷயங்களைக் கவனியுங்கள்.
முதலில், நீங்கள் இங்கு பார்க்கும் அனைத்தும் ஒரு இடைமுகம்.
இரண்டாவதாக, அம்புகள் "பரம்பரை" என்று பொருள்.
"வேறு வார்த்தைகளில் கூறுவதானால், பட்டியல், அமை மற்றும் வரிசை ஆகியவை சேகரிப்பைப் பெறுகின்றன, ஆனால் வரைபடம் பெறவில்லையா?"
"ஆம். சுருக்க வகுப்புகள் இந்த இடைமுகங்களைப் பெறுகின்றன, அதையொட்டி, சுருக்க வகுப்புகளைப் பற்றி உங்களுக்குத் தெரிந்த செயலாக்கங்கள் பெறுகின்றன: ArrayList, Hashtable, TreeSet,... "
"நீங்கள் சொல்வது சரிதான்."
"இப்போது இந்த இடைமுகங்களின் முறைகள் எதற்காக என்று பார்ப்போம்:"
மறுசெலுத்தக்கூடிய முறைகள் <E>: இடைமுகம்:
முறைகள் | விளக்கம் |
---|---|
Iterator<T> iterator(); |
ஒரு இடிரேட்டர் பொருளை வழங்குகிறது. |
"அது போதுமானதாகத் தெரியவில்லை."
"சரி, அதுதான் எத்தனை இருக்கிறது. திரும்பத் திரும்பச் செய்பவர்களுக்கு அவ்வளவுதான். நாங்கள் இப்போது அவற்றை மறைக்க மாட்டோம், ஆனால் விரைவில் அவற்றை விரிவாகக் கூறுவோம்."
சேகரிப்பு முறைகள் <E>: இடைமுகம்:
முறைகள் | விளக்கம் |
---|---|
boolean add(E e); |
சேகரிப்பில் ஒரு உறுப்பைச் சேர்க்கிறது |
boolean addAll(Collection<? extends E> c); |
சேகரிப்பில் கூறுகளைச் சேர்க்கிறது |
void clear(); |
சேகரிப்பிலிருந்து அனைத்து கூறுகளையும் நீக்குகிறது |
boolean contains(Object o); |
சேகரிப்பில் உறுப்பு உள்ளதா என சரிபார்க்கிறது. |
boolean containsAll(Collection<?> c); |
சேகரிப்பில் கூறுகள் உள்ளதா என சரிபார்க்கிறது. |
boolean equals(Object o); |
சேகரிப்புகள் சமமாக உள்ளதா என்பதைப் பார்க்கவும் |
int hashCode(); |
ஹாஷ் குறியீட்டை வழங்கும் |
boolean isEmpty(); |
சேகரிப்பு காலியாக உள்ளதா என சரிபார்க்கிறது. |
Iterator<E> iterator(); |
ஒரு இடிரேட்டர் பொருளை வழங்குகிறது |
boolean remove(Object o); |
சேகரிப்பிலிருந்து ஒரு உறுப்பை நீக்குகிறது |
boolean removeAll(Collection<?> c); |
சேகரிப்பிலிருந்து கூறுகளை நீக்குகிறது |
boolean retainAll(Collection<?> c); |
c இல் இல்லாத அனைத்து கூறுகளையும் நீக்குகிறது |
int size(); |
சேகரிப்பின் அளவை வழங்குகிறது |
Object[] toArray(); |
தொகுப்பை அணிவரிசையாக மாற்றுகிறது |
<T> T[] toArray(T[] a); |
தொகுப்பை அணிவரிசையாக மாற்றுகிறது |
"நான் ஏற்கனவே இங்கே எல்லாவற்றிலும் உறுதியாக இருக்கிறேன். இந்த முறைகளில் பாதியைப் பயன்படுத்தினேன், மற்ற பாதியை நான் சந்தித்தேன்."
"அருமை, பிறகு தொடரலாம்."
பட்டியலின் முறைகள் <E>: இடைமுகம்:
முறைகள் | விளக்கம் |
---|---|
void add(int index, E element); |
சேகரிப்பின் நடுவில் கூறுகளைச் சேர்க்கிறது |
boolean addAll(int index, Collection<? extends E> c); |
சேகரிப்பில் கூறுகளைச் சேர்க்கிறது |
E get(int index); |
குறியீட்டின் அடிப்படையில் ஒரு உறுப்பை வழங்கும் |
int indexOf(Object o); |
ஒரு தனிமத்தின் குறியீட்டை (எண்) வழங்கும் |
int lastIndexOf(Object o); |
கடைசி உறுப்பின் குறியீட்டை வழங்கும். |
ListIterator<E> listIterator(); |
பட்டியலுக்கான மறு செய்கையை வழங்கும் |
ListIterator<E> listIterator(int index); |
பட்டியலுக்கான மறு செய்கையை வழங்கும் |
E remove(int index); |
ஒரு உறுப்பை அதன் குறியீட்டின் மூலம் நீக்குகிறது |
E set(int index, E element); |
குறியீட்டின்படி புதிய மதிப்பை அமைக்கிறது |
List<E> subList(int fromIndex, int toIndex); |
துணைத் தொகுப்பை வழங்குகிறது |
"இங்கேயும் புதிதாக எதுவும் இல்லை. சேகரிப்புகளைப் பற்றி எனக்கு ஏற்கனவே எல்லாமே தெரியும், அதைப்பற்றி என்னால் மகிழ்ச்சியாக இருக்க முடியாது."
"சரி, உங்களை ஆச்சரியப்படுத்தும் ஒன்றை என்னால் கண்டுபிடிக்க முடியும் என்று நினைக்கிறேன். ஆனால் இடைமுகங்களைத் தொடர்ந்து ஆய்வு செய்வோம்:"
தொகுப்பின் முறைகள் <E>: இடைமுகம்:
முறைகள் | விளக்கம் |
---|---|
|
"செட் இடைமுகத்தில் புதிய முறைகள் எதுவும் இல்லை - அது மரபுரிமையாக மட்டுமே உள்ளது."
"ஆமாம், இண்டரபிள் இடைமுகத்திலும் எதுவும் இல்லை என்று பார்த்தேன்.
"மறுபுறம், குறைவான முறைகள் நினைவில் கொள்வது குறைவு!"
"உங்கள் வாழ்க்கையை உறுதிப்படுத்தும் நம்பிக்கை எனக்கு மகிழ்ச்சி அளிக்கிறது."
"அமைவு இடைமுகம் இரண்டு இடைமுகங்கள் மூலம் பெறப்படுகிறது: SortedSet மற்றும் NavigableSet. ஆனால் நான் அவற்றைக் கடந்து செல்லமாட்டேன் அல்லது நாங்கள் முடிக்க மாட்டோம்."
"மாறாக, ஜாவாவில் சேகரிப்புகளை விவரிக்கும் வகுப்புகள் மற்றும் இடைமுகங்களின் பொதுவான படத்தை உங்களுக்கு தருகிறேன்."
"கொண்டு வா."
"அப்படியானால் இறுக்கமாகப் பிடித்துக்கொள்:"

"ஆஹா, அது மிகப்பெரியது!"
"சரி, அது பெரிதாக இல்லை. மேலும், சுருக்க வகுப்புகள் முற்றிலும் விருப்பமானவை என்பதை நினைவில் கொள்ளுங்கள். ஆனால் எந்த வகுப்பு எந்த இடைமுகங்களைச் செயல்படுத்துகிறது என்பதை நினைவில் கொள்வது நல்லது. அது அடிக்கடி கைக்கு வரும்."
"ஓ, சில சேகரிப்புகள் வழக்கற்றுப் போனதாகக் கருதப்படுவதையும் நான் கவனிக்க விரும்புகிறேன்."
"அவை எவை?"
"நான் வெக்டர், ஸ்டாக், அகராதி மற்றும் ஹேஷ்டேபிள் வகுப்புகளைப் பற்றி பேசுகிறேன். இவை சாதாரண சேகரிப்புகளின் ஒத்திசைக்கப்பட்ட (த்ரெட்-பாதுகாப்பான) பதிப்புகள்."
"ஆனால் ஜாவா ஒரு சிறப்பு ஒத்திசைவு நூலகத்தைச் சேர்த்துள்ளது, இது மற்ற த்ரெட்களில் இருந்து அணுகக்கூடியது மட்டுமல்லாமல், மிகவும் திறமையான செயலாக்கத்தையும் கொண்டுள்ளது. ஹேஷ்டேபிளை விட ConcurrentHashMap மிகவும் திறமையானது ."
"நீங்கள் வெக்டார், ஸ்டாக், அகராதி மற்றும் ஹேஸ்டேபிள் தொகுப்புகளைப் பயன்படுத்தலாம், ஆனால் அது பரிந்துரைக்கப்படவில்லை."
"புரிகிறது, நான் அதை மனதில் வைத்துக்கொள்கிறேன்."
"நன்றி, எல்லி!"
GO TO FULL VERSION