Класс LinkedHashSet наследуется от HashSet не добавляя новых методов. Этот класс позволяет хранить и выводить данные в том порядке, в котором они были добавлены в коллекцию. Физически данные хранятся в LinkedHashMap. Класс LinkedHashSet является обобщенным. Пример:
//класс с координатами - элемент коллекции class Coordinate{ private int X; private int Y;
public Coordinate(int X, int Y) { this.X = X; this.Y = Y; }
@Override public String toString() { return "X: " + X + ", Y: " + Y; }
@Override public boolean equals(Object obj) { if(obj instanceof Coordinate){ Coordinate c = (Coordinate)obj; return c.X == this.X && c.Y == this.Y; }else { return super.equals(obj); } }
@Override public int hashCode() { int hash = 7; hash = 59 * hash + this.X; hash = 59 * hash + this.Y; return hash; } }
void CollectionToTextArea(HashSet<Coordinate> c, JTextArea ta){ for(Coordinate item: c){ta.append(item.toString() + "\n"); } ta.append("--------------------------------------------------" + "\n"); } void CoordinateToTextArea(Coordinate c, JTextArea ta, String comment){ if(c != null){ ta.append(comment + c.toString() + "\n"); } } //выводим все содержимое очереди в текстовую область (при этом очередь очищается) void RemoveAllQueueElements(Queue <Coordinate> q){ Coordinate c = null; c = q.poll(); while(c != null) { jTextArea1.append("Удалили из очереди: " + c.toString() + "\n"); c = q.poll(); } } void IteratorToTextArea(Iterator <Coordinate> iter, JTextArea ta){ if (iter != null & ta != null){ while(iter.hasNext()){ ta.append(iter.next().toString() + "\n"); } } }; private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) { //создаем коллекцию хеш-таблицу LinkedHashSet <Coordinate> hs = new LinkedHashSet <Coordinate>(); //будем осуществлять доступ к коллекции через интерфейс Set Set <Coordinate> sitf = hs; //добавляем элемнты в коллекцию for(int i = 0; i < 10; i ++){ sitf.add(new Coordinate(i, i)); } //выводим коллекцию в текстовую область - выводятся элементы //не в том порядке котором добавлялись в коллекцию CollectionToTextArea(hs, jTextArea1); //выводим через итератор в текстовую область //получаем тот же результат, что и выше IteratorToTextArea(sitf.iterator(), jTextArea1); //осуществляем поиск созданной координаты в хеш-таблице Coordinate c = new Coordinate(5, 5); if (sitf.contains(c)) CoordinateToTextArea(c, jTextArea1, "Найден элемнт в коллекции типа LinkedHashSet:"); }
|