<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FCollections_Data_Structure%2FGeneral_Collections</id>
		<title>Java/Collections Data Structure/General Collections - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FCollections_Data_Structure%2FGeneral_Collections"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/General_Collections&amp;action=history"/>
		<updated>2026-04-06T04:35:55Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Collections_Data_Structure/General_Collections&amp;diff=9129&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/General_Collections&amp;diff=9129&amp;oldid=prev"/>
				<updated>2010-06-01T07:25:52Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 07:25, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Collections_Data_Structure/General_Collections&amp;diff=9128&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/General_Collections&amp;diff=9128&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:48Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Collections: List, Set, SortedSet, LinkedHashSet, Map, LinkedHashMap ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Collection;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.HashSet;&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
import java.util.LinkedHashMap;&lt;br /&gt;
import java.util.LinkedHashSet;&lt;br /&gt;
import java.util.LinkedList;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import java.util.Set;&lt;br /&gt;
import java.util.SortedMap;&lt;br /&gt;
import java.util.SortedSet;&lt;br /&gt;
import java.util.TreeMap;&lt;br /&gt;
import java.util.TreeSet;&lt;br /&gt;
public class CollectionAll {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    List list1 = new LinkedList();&lt;br /&gt;
    list1.add(&amp;quot;list&amp;quot;);&lt;br /&gt;
    list1.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    list1.add(&amp;quot;x&amp;quot;);&lt;br /&gt;
    list1.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    traverse(list1); &lt;br /&gt;
    List list2 = new ArrayList();&lt;br /&gt;
    list2.add(&amp;quot;list&amp;quot;);&lt;br /&gt;
    list2.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    list2.add(&amp;quot;x&amp;quot;);&lt;br /&gt;
    list2.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    traverse(list2); &lt;br /&gt;
    Set set1 = new HashSet();&lt;br /&gt;
    set1.add(&amp;quot;set&amp;quot;);&lt;br /&gt;
    set1.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    set1.add(&amp;quot;x&amp;quot;);&lt;br /&gt;
    set1.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    traverse(set1); &lt;br /&gt;
    SortedSet set2 = new TreeSet();&lt;br /&gt;
    set2.add(&amp;quot;set&amp;quot;);&lt;br /&gt;
    set2.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    set2.add(&amp;quot;x&amp;quot;);&lt;br /&gt;
    set2.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    traverse(set2); &lt;br /&gt;
    LinkedHashSet set3 = new LinkedHashSet();&lt;br /&gt;
    set3.add(&amp;quot;set&amp;quot;);&lt;br /&gt;
    set3.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    set3.add(&amp;quot;x&amp;quot;);&lt;br /&gt;
    set3.add(&amp;quot;dup&amp;quot;);&lt;br /&gt;
    traverse(set3); &lt;br /&gt;
    Map m1 = new HashMap();&lt;br /&gt;
    m1.put(&amp;quot;map&amp;quot;, &amp;quot;jexp&amp;quot;);&lt;br /&gt;
    m1.put(&amp;quot;dup&amp;quot;, &amp;quot;Kava2s&amp;quot;);&lt;br /&gt;
    m1.put(&amp;quot;x&amp;quot;, &amp;quot;Mava2s&amp;quot;);&lt;br /&gt;
    m1.put(&amp;quot;dup&amp;quot;, &amp;quot;Lava2s&amp;quot;);&lt;br /&gt;
    traverse(m1.keySet()); &lt;br /&gt;
    traverse(m1.values()); &lt;br /&gt;
    SortedMap m2 = new TreeMap();&lt;br /&gt;
    m2.put(&amp;quot;map&amp;quot;, &amp;quot;jexp&amp;quot;);&lt;br /&gt;
    m2.put(&amp;quot;dup&amp;quot;, &amp;quot;Kava2s&amp;quot;);&lt;br /&gt;
    m2.put(&amp;quot;x&amp;quot;, &amp;quot;Mava2s&amp;quot;);&lt;br /&gt;
    m2.put(&amp;quot;dup&amp;quot;, &amp;quot;Lava2s&amp;quot;);&lt;br /&gt;
    traverse(m2.keySet()); &lt;br /&gt;
    traverse(m2.values()); &lt;br /&gt;
    LinkedHashMap /* from String to String */m3 = new LinkedHashMap();&lt;br /&gt;
    m3.put(&amp;quot;map&amp;quot;, &amp;quot;jexp&amp;quot;);&lt;br /&gt;
    m3.put(&amp;quot;dup&amp;quot;, &amp;quot;Kava2s&amp;quot;);&lt;br /&gt;
    m3.put(&amp;quot;x&amp;quot;, &amp;quot;Mava2s&amp;quot;);&lt;br /&gt;
    m3.put(&amp;quot;dup&amp;quot;, &amp;quot;Lava2s&amp;quot;);&lt;br /&gt;
    traverse(m3.keySet()); &lt;br /&gt;
    traverse(m3.values()); &lt;br /&gt;
  }&lt;br /&gt;
  static void traverse(Collection coll) {&lt;br /&gt;
    Iterator iter = coll.iterator();&lt;br /&gt;
    while (iter.hasNext()) {&lt;br /&gt;
      String elem = (String) iter.next();&lt;br /&gt;
      System.out.print(elem + &amp;quot; &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Simple demonstrations of the Collections utilities ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
// : c11:Utilities.java&lt;br /&gt;
// Simple demonstrations of the Collections utilities.&lt;br /&gt;
// From &amp;quot;Thinking in Java, 3rd ed.&amp;quot; (c) Bruce Eckel 2002&lt;br /&gt;
// www.BruceEckel.ru. See copyright notice in CopyRight.txt.&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Arrays;&lt;br /&gt;
import java.util.Collections;&lt;br /&gt;
import java.util.ruparator;&lt;br /&gt;
import java.util.Enumeration;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Vector;&lt;br /&gt;
public class Utilities {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    List list = Arrays.asList(&amp;quot;one Two three Four five six one&amp;quot;.split(&amp;quot; &amp;quot;));&lt;br /&gt;
    System.out.println(list);&lt;br /&gt;
    System.out.println(&amp;quot;max: &amp;quot; + Collections.max(list));&lt;br /&gt;
    System.out.println(&amp;quot;min: &amp;quot; + Collections.min(list));&lt;br /&gt;
    AlphabeticComparator comp = new AlphabeticComparator();&lt;br /&gt;
    System.out.println(&amp;quot;max w/ comparator: &amp;quot; + Collections.max(list, comp));&lt;br /&gt;
    System.out.println(&amp;quot;min w/ comparator: &amp;quot; + Collections.min(list, comp));&lt;br /&gt;
    List sublist = Arrays.asList(&amp;quot;Four five six&amp;quot;.split(&amp;quot; &amp;quot;));&lt;br /&gt;
    System.out.println(&amp;quot;indexOfSubList: &amp;quot;&lt;br /&gt;
        + Collections.indexOfSubList(list, sublist));&lt;br /&gt;
    System.out.println(&amp;quot;lastIndexOfSubList: &amp;quot;&lt;br /&gt;
        + Collections.lastIndexOfSubList(list, sublist));&lt;br /&gt;
    Collections.replaceAll(list, &amp;quot;one&amp;quot;, &amp;quot;Yo&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;replaceAll: &amp;quot; + list);&lt;br /&gt;
    Collections.reverse(list);&lt;br /&gt;
    System.out.println(&amp;quot;reverse: &amp;quot; + list);&lt;br /&gt;
    Collections.rotate(list, 3);&lt;br /&gt;
    System.out.println(&amp;quot;rotate: &amp;quot; + list);&lt;br /&gt;
    List source = Arrays.asList(&amp;quot;in the matrix&amp;quot;.split(&amp;quot; &amp;quot;));&lt;br /&gt;
    Collections.copy(list, source);&lt;br /&gt;
    System.out.println(&amp;quot;copy: &amp;quot; + list);&lt;br /&gt;
    Collections.swap(list, 0, list.size() - 1);&lt;br /&gt;
    System.out.println(&amp;quot;swap: &amp;quot; + list);&lt;br /&gt;
    Collections.fill(list, &amp;quot;pop&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;fill: &amp;quot; + list);&lt;br /&gt;
    List dups = Collections.nCopies(3, &amp;quot;snap&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;dups: &amp;quot; + dups);&lt;br /&gt;
    // Getting an old-style Enumeration:&lt;br /&gt;
    Enumeration e = Collections.enumeration(dups);&lt;br /&gt;
    Vector v = new Vector();&lt;br /&gt;
    while (e.hasMoreElements())&lt;br /&gt;
      v.addElement(e.nextElement());&lt;br /&gt;
    // Converting an old-style Vector&lt;br /&gt;
    // to a List via an Enumeration:&lt;br /&gt;
    ArrayList arrayList = Collections.list(v.elements());&lt;br /&gt;
    System.out.println(&amp;quot;arrayList: &amp;quot; + arrayList);&lt;br /&gt;
  }&lt;br /&gt;
} ///:~&lt;br /&gt;
class AlphabeticComparator implements Comparator {&lt;br /&gt;
  public int compare(Object o1, Object o2) {&lt;br /&gt;
    String s1 = (String) o1;&lt;br /&gt;
    String s2 = (String) o2;&lt;br /&gt;
    return s1.toLowerCase().rupareTo(s2.toLowerCase());&lt;br /&gt;
  }&lt;br /&gt;
} ///:~&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Sometimes methods defined in the Collection interfaces don&amp;quot;t work ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
// : c11:Unsupported.java&lt;br /&gt;
// Sometimes methods defined in the Collection interfaces don&amp;quot;t work!&lt;br /&gt;
// {ThrowsException}&lt;br /&gt;
// From &amp;quot;Thinking in Java, 3rd ed.&amp;quot; (c) Bruce Eckel 2002&lt;br /&gt;
// www.BruceEckel.ru. See copyright notice in CopyRight.txt.&lt;br /&gt;
import java.util.Arrays;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.ListIterator;&lt;br /&gt;
public class Unsupported {&lt;br /&gt;
  static List a = Arrays.asList(&amp;quot;one two three four five six seven eight&amp;quot;&lt;br /&gt;
      .split(&amp;quot; &amp;quot;));&lt;br /&gt;
  static List a2 = a.subList(3, 6);&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    System.out.println(a);&lt;br /&gt;
    System.out.println(a2);&lt;br /&gt;
    System.out.println(&amp;quot;a.contains(&amp;quot; + a.get(0) + &amp;quot;) = &amp;quot;&lt;br /&gt;
        + a.contains(a.get(0)));&lt;br /&gt;
    System.out.println(&amp;quot;a.containsAll(a2) = &amp;quot; + a.containsAll(a2));&lt;br /&gt;
    System.out.println(&amp;quot;a.isEmpty() = &amp;quot; + a.isEmpty());&lt;br /&gt;
    System.out.println(&amp;quot;a.indexOf(&amp;quot; + a.get(5) + &amp;quot;) = &amp;quot;&lt;br /&gt;
        + a.indexOf(a.get(5)));&lt;br /&gt;
    // Traverse backwards:&lt;br /&gt;
    ListIterator lit = a.listIterator(a.size());&lt;br /&gt;
    while (lit.hasPrevious())&lt;br /&gt;
      System.out.print(lit.previous() + &amp;quot; &amp;quot;);&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    // Set the elements to different values:&lt;br /&gt;
    for (int i = 0; i &amp;lt; a.size(); i++)&lt;br /&gt;
      a.set(i, &amp;quot;47&amp;quot;);&lt;br /&gt;
    System.out.println(a);&lt;br /&gt;
    // Compiles, but won&amp;quot;t run:&lt;br /&gt;
    lit.add(&amp;quot;X&amp;quot;); // Unsupported operation&lt;br /&gt;
    a.clear(); // Unsupported&lt;br /&gt;
    a.add(&amp;quot;eleven&amp;quot;); // Unsupported&lt;br /&gt;
    a.addAll(a2); // Unsupported&lt;br /&gt;
    a.retainAll(a2); // Unsupported&lt;br /&gt;
    a.remove(a.get(0)); // Unsupported&lt;br /&gt;
    a.removeAll(a2); // Unsupported&lt;br /&gt;
  }&lt;br /&gt;
} ///:~&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Using the Collections.synchronized methods ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
// : c11:Synchronization.java&lt;br /&gt;
// Using the Collections.synchronized methods.&lt;br /&gt;
// From &amp;quot;Thinking in Java, 3rd ed.&amp;quot; (c) Bruce Eckel 2002&lt;br /&gt;
// www.BruceEckel.ru. See copyright notice in CopyRight.txt.&lt;br /&gt;
import java.util.ArrayList;&lt;br /&gt;
import java.util.Collection;&lt;br /&gt;
import java.util.Collections;&lt;br /&gt;
import java.util.HashMap;&lt;br /&gt;
import java.util.HashSet;&lt;br /&gt;
import java.util.List;&lt;br /&gt;
import java.util.Map;&lt;br /&gt;
import java.util.Set;&lt;br /&gt;
public class Synchronization {&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    Collection c = Collections.synchronizedCollection(new ArrayList());&lt;br /&gt;
    List list = Collections.synchronizedList(new ArrayList());&lt;br /&gt;
    Set s = Collections.synchronizedSet(new HashSet());&lt;br /&gt;
    Map m = Collections.synchronizedMap(new HashMap());&lt;br /&gt;
  }&lt;br /&gt;
} ///:~&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>