-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMain.java
More file actions
126 lines (100 loc) · 5.97 KB
/
Main.java
File metadata and controls
126 lines (100 loc) · 5.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import java.util.*;
/**
* @author Ковалев Дмитрий
* Задание:
* 1. создать журнал системных сообщений,
* 2. хранить его в LinkedHashSet,
* 3. добавить в коллекцию данные,
* 4. отсортировать данные,
* 5. вывести содержимое коллекции,
* 6. найти максимальный элемент,
* 7. удалить нужный элемент,
* 8. объединить две коллекции.
*
* Ввод: Название Hash происходит от понятия хэш-функция.
* Хэш-функция — это функция, сужающая множество значений объекта до некоторого подмножества целых чисел.
* Класс Object имеет метод hashCode(), который используется классом HashSet для эффективного размещения объектов, заносимых в коллекцию.
* В классах объектов, заносимых в HashSet, этот метод должен быть переопределен (override).
*
* Класс LinkedHashSet расширяет класс HashSet, не добавляя никаких новых методов.
* Класс поддерживает связный список элементов набора в том порядке, в котором они вставлялись.
* Это позволяет организовать упорядоченную итерацию вставки в набор.
*/
public class Main {
private static LinkedHashSet<SystemError> systemErrors;
private static Iterator<SystemError> errorIterator;
public static void main(String[] params) {
systemErrors = new LinkedHashSet<SystemError>();
/**
* Добавление объектов в LinkedHashSet.
*/
systemErrors.add(new SystemError(1, "File not found", "The system cannot find the file"));
systemErrors.add(new SystemError(2, "Not enough memory", "Not enough storage is available"));
systemErrors.add(new SystemError(4, "Read error", "The system cannot read the file"));
systemErrors.add(new SystemError(3, "Write error", "The system cannot write file"));
systemErrors.add(new SystemError(5, "Network access denied", "Network access is denied"));
systemErrors.add(new SystemError(6, "Buffer overflow", "The file name is too long"));
System.out.println('\n' + "Base collection: " + '\n');
errorIterator = systemErrors.iterator();
while (errorIterator.hasNext()) {
System.out.println(errorIterator.next());
}
sort();
findMax();
removeSpecifiedElement();
combine();
}
/**
* Функция для объединения коллекций.
* LinkedHashSet.addAll добавляет все элементы определенной коллекции в set, если они не присутствуют в этом set.
*/
private static void combine() {
LinkedHashSet<SystemError> anotherSystemErrors = new LinkedHashSet<SystemError>();
anotherSystemErrors.add(new SystemError(7, "Max sessions reached", "The maximum number of sessions has been reached."));
anotherSystemErrors.add(new SystemError(8, "Restart failed", "The restart operation failed."));
anotherSystemErrors.add(new SystemError(9, "Shutdown error", "The shutdown operation failed."));
systemErrors.addAll(anotherSystemErrors);
System.out.println('\n' + "After combining: " + '\n');
errorIterator = systemErrors.iterator();
while (errorIterator.hasNext()) {
System.out.println(errorIterator.next());
}
}
/**
* Функция сортировки.
* Arrays.sort сортирует массив объектов в порядке убывания.
* Arrays.asList возвращает лист определенного размера, содержащего элементы массива.
*/
private static void sort() {
Object[] errorsArray = systemErrors.toArray();
Arrays.sort(errorsArray);
System.out.println('\n' + "Sorted base collection: " + Arrays.asList(errorsArray));
}
/**
* Функция поиска максимального элемента.
* Collections.max возвращает максимальный элемент данной коллекции.
*/
private static void findMax(){
SystemError max = Collections.max(systemErrors);
System.out.println('\n' + "Max: " + max);
}
/**
* Функция удаления нужного элемента.
* LinkedHashSet.remove удаляет определенный элемент, если он присутствует.
* Для проверки присутствия элемента в коллекции используются методы hashCode и equals.
* Если hashCode элемента, присутствующего в коллекции и элемента, который необходимо удалить, совпадают,
* то этот элемент удаляется.
*/
private static void removeSpecifiedElement(){
SystemError toRemove = new SystemError(1, "File not found", "The system cannot find the file");
systemErrors.remove(toRemove);
System.out.println('\n' + "After removal:" + '\n');
errorIterator = systemErrors.iterator();
while (errorIterator.hasNext()) {
System.out.println(errorIterator.next());
}
}
}
/**
* Вывод: в работе были рассмотрены методы работы с коллекциями в общем и с LinkedHashSet в частности.
*/