प्रौद्योगिकी साझेदारी

java Collections class इत्यस्य परिचयः

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

जावा'sjava.util.Collectionsवर्गाः संग्रहाणां (यथा सूचीः, समुच्चयः, नक्शाः च) परिवर्तनार्थं वा प्रत्यागन्तुं वा स्थिरविधिसमूहं प्रददति ।Collections वर्गः एकः उपयोगितावर्गः अस्ति यः संग्रहेषु सुविधाजनकं एल्गोरिदम्, संचालनं च प्रदातुं विनिर्मितः अस्ति ।अथ युग्मम्Collectionsवर्गाणां परिचयः तेषां सामान्यतया प्रयुक्तानां पद्धतीनां च परिचयः।

सामान्यविधिनां सारांशः

  • प्रकारंsort(List<T> list)sort(List<T> list, Comparator<? super T> c)
  • अन्वेषयbinarySearch(List<? extends Comparable<? super T>> list, T key)binarySearch(List<? extends T> list, T key, Comparator<? super T> c)
  • विपरीतreverse(List<?> list)
  • परिभ्रमतिrotate(List<?> list, int distance)
  • पूरणम्fill(List<? super T> list, T obj)
  • प्रतिलिपिcopy(List<? super T> dest, List<? extends T> src)
  • min and maxmin(Collection<? extends T> coll)max(Collection<? extends T> coll)
  • समन्वय संग्रहsynchronizedList(List<T> list)synchronizedSet(Set<T> s)synchronizedMap(Map<K, V> m)
  • अपरिवर्तनीय संग्रहunmodifiableList(List<? extends T> list)unmodifiableSet(Set<? extends T> s)unmodifiableMap(Map<? extends K, ? extends V> m)

प्रकारं
  • sort(List<T> list): सूचीं आरोहणक्रमेण क्रमयन्तु, सूचीयां तत्त्वानि कार्यान्वितुं अर्हन्तिComparableअन्तरफलकम् ।
  1. List<Integer> numbers = Arrays.asList(5, 3, 1, 4, 2);
  2. Collections.sort(numbers); // 排序后,numbers为 [1, 2, 3, 4, 5]
  • sort(List<T> list, Comparator<? super T> c): निर्दिष्टतुलनानुसारं सूचीं क्रमयति ।
  1. List<String> names = Arrays.asList("Charlie", "Alice", "Bob");
  2. // 根据字符串长度排序
  3. Collections.sort(names, (s1, s2) -> s1.length() - s2.length());

नोटः: Collections.sort(names, (s1, s2) -&gt; s1.length() - s2.length()) (s1, s2) -&gt; s1.length() - s2.length() इदं Lambda Expression अस्ति Comparator interface इत्यस्य compare विधिं कार्यान्वितुं प्रयुक्तम् ।

अन्वेषय
  • binarySearch(List<? extends Comparable<? super T>> list, T key) : सूचीयां एकं तत्त्वं अन्वेष्टुं अनुक्रमणिकां च प्रत्यागन्तुं द्विचक्रीय अन्वेषणस्य उपयोगं कुर्वन्तु । सूची अवश्यं क्रमबद्धा भवितुमर्हति।
  1. List<Integer> sortedNumbers = Arrays.asList(1, 2, 3, 4, 5);
  2. int index = Collections.binarySearch(sortedNumbers, 3); // 返回索引 2
  • binarySearch(List<? extends T> list, T key, Comparator<? super T> c): निर्दिष्टस्य तुलनात्मकस्य सूचीयां एकं तत्त्वं अन्वेष्टुं द्विचक्रीय अन्वेषणस्य उपयोगं कुर्वन्तु ।
  1. List<String> sortedNames = Arrays.asList("Alice", "Bob", "Charlie");
  2. int index = Collections.binarySearch(sortedNames, "Bob", String::compareTo); // 返回索引 1
अधिकतमं न्यूनतमं च मूल्यं
  • max(Collection<? extends T> coll): संग्रहे बृहत्तमं तत्त्वं प्रत्यागच्छति ।
  1. List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
  2. int max = Collections.max(numbers); // 返回 5
  • min(Collection<? extends T> coll): सेट् मध्ये लघुतमं तत्त्वं प्रत्यागच्छति ।
int min = Collections.min(numbers); // 返回 1
विपर्ययक्रमः
  • reverse(List<?> list): सूचीस्थतत्त्वानि विपर्यययन्तु।
  1. List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
  2. Collections.reverse(numbers); // 反转后,numbers为 [5, 4, 3, 2, 1]
यादृच्छिकीकरण
  • shuffle(List<?> list): यादृच्छिकरूपेण सूचीं फेरबदलं कुर्वन्तु।
Collections.shuffle(numbers); // numbers的元素顺序将被随机打乱
पूरणम्
  • fill(List<? super T> list, T obj): सूचीयां सर्वाणि तत्त्वानि निर्दिष्टेन तत्त्वेन प्रतिस्थापयन्तु ।
  1. List<String> list = new ArrayList<>(Arrays.asList("a", "b", "c"));
  2. Collections.fill(list, "z"); // list 现在是 ["z", "z", "z"]
प्रतिलिपि
  • copy(List<? super T> dest, List<? extends T> src): स्रोतसूचौ सर्वाणि तत्त्वानि लक्ष्यसूचौ प्रतिलिपिं करोति ।
  1. List<String> dest = Arrays.asList(new String[3]);
  2. List<String> src = Arrays.asList("a", "b", "c");
  3. Collections.copy(dest, src); // dest 现在是 ["a", "b", "c"]
अपरिवर्तनीय संग्रह
  • unmodifiableList(List<? extends T> list): अपरिवर्तनीयं दृश्यं प्रत्यागच्छति ।
  1. List<String> list = Arrays.asList("a", "b", "c");
  2. List<String> unmodifiableList = Collections.unmodifiableList(list);
  3. // unmodifiableList.add("d"); // 会抛出 UnsupportedOperationException
समन्वय संग्रह
  • synchronizedList(List<T> list): सूत्र-सुरक्षितसूचीं प्रत्यागच्छति ।
  1. List<String> list = new ArrayList<>();
  2. List<String> syncList = Collections.synchronizedList(list);

उदाहरणसारांशः

अत्र दर्शयति व्यापकं उदाहरणम्Collectionsवर्गानां केचन सामान्यविधयः : १.

  1. import java.util.*;
  2. public class CollectionsExample {
  3. public static void main(String[] args) {
  4. List<Integer> numbers = new ArrayList<>(Arrays.asList(5, 3, 1, 4, 2));
  5. // 排序
  6. Collections.sort(numbers);
  7. System.out.println("排序后: " + numbers);
  8. // 反转
  9. Collections.reverse(numbers);
  10. System.out.println("反转后: " + numbers);
  11. // 随机打乱
  12. Collections.shuffle(numbers);
  13. System.out.println("随机打乱后: " + numbers);
  14. // 查找最大和最小值
  15. int max = Collections.max(numbers);
  16. int min = Collections.min(numbers);
  17. System.out.println("最大值: " + max + ", 最小值: " + min);
  18. // 二分搜索
  19. Collections.sort(numbers);
  20. int index = Collections.binarySearch(numbers, 3);
  21. System.out.println("元素 3 的索引: " + index);
  22. // 同步集合
  23. List<String> syncList = Collections.synchronizedList(new ArrayList<>());
  24. syncList.add("a");
  25. syncList.add("b");
  26. System.out.println("同步集合: " + syncList);
  27. }
  28. }

उपयोगेनCollectionsवर्गेन प्रदत्ताः एताः पद्धतयः संग्रहे विविधानि कार्याणि सहजतया कर्तुं शक्नुवन्ति, येन कोडस्य पठनीयता, परिपालनक्षमता च सुधरति ।

refer to : १.

संग्रह (Java SE 17 & JDK 17)