forked from sevastyan_b/SSPR_25
Added Readme
This commit is contained in:
parent
8ebd9756e6
commit
30fb493f94
7
.gitignore
vendored
7
.gitignore
vendored
@ -24,3 +24,10 @@
|
||||
hs_err_pid*
|
||||
replay_pid*
|
||||
|
||||
/.idea/.gitignore
|
||||
/.idea/.name
|
||||
/.idea/misc.xml
|
||||
/.idea/modules.xml
|
||||
/savinov_roman_lab1/savinov_roman_lab1.iml
|
||||
/.idea/SSPR_25.iml
|
||||
/.idea/vcs.xml
|
||||
|
58
savinov_roman_lab1/README.md
Normal file
58
savinov_roman_lab1/README.md
Normal file
@ -0,0 +1,58 @@
|
||||
# Лабораторная №1
|
||||
Разработка многопоточного приложения с использованием Java Concurrency
|
||||
согласно варианту задания.
|
||||
Необходимо:
|
||||
1 Разработать однопоточный вариант алгоритма и замерить время его работы.
|
||||
2 Разработать параллельный вариант алгоритма с использованием
|
||||
ThreadPoolExecutor и замерить время его работы
|
||||
3 Разработать параллельный вариант алгоритма с использованием ForkJoinPoll
|
||||
и замерить время его работы.
|
||||
**ВАЖНО**: Массив генерируется до работы всех вариантов алгоритмов. Все три
|
||||
алгоритма обрабатывают три одинаковых массива.
|
||||
## Вариант и задание
|
||||
22 Упорядочить столбцы матрицы по возрастанию первых элементов.
|
||||
## Как запустить лабораторную работу
|
||||
Минимальная требуемая версия jdk - 21.0.2
|
||||
Для запуска лабораторной работы нужно в директории с java файлами выполнить следующее:
|
||||
* >javac -d /путь/к/выходной/директории *.java
|
||||
* перейти к выходной директории при помощи команды cd
|
||||
* внутри директории с .class файлами нужно выполнить команду:
|
||||
* >java Main
|
||||
|
||||
## Какие технологии использовались
|
||||
В этой лабораторной использовалась следующие пакеты:
|
||||
* java.util.concurrent — инструменты для многопоточности (пулы потоков, синхронизация).
|
||||
* ForkJoinPool — пул потоков для параллельных задач по принципу "разделяй и властвуй".
|
||||
* RecursiveAction — задача без возврата результата, которую можно разбить на подзадачи.
|
||||
* Logger — журнал для логирования сообщений и ошибок.
|
||||
|
||||
## Что она делает
|
||||
Согласно заданию программа создает матрицу состоящую из 5000 строчек и 5000 столбцов.
|
||||
Программа реализует сортировку слиянием за тем исключением, что при перестановке перестановки осуществляются столбцами.
|
||||
Я попытался создать некое подобие класса-управленца, ArrayController, но выглядит так, будто это лишнее.
|
||||
## Тесты
|
||||
Для тестов был создан отдельный метод в классе Main, который прогоняет 2 матрицы для каждого алгоритма сортировки.
|
||||
Программа генерирует и сортирует большую матрицу только тогда, когда тесты успешно проходят.
|
||||
Сами тесты:
|
||||
#### Пример 1
|
||||
**Входные данные**
|
||||
{3, 8, 4, 10, 2, 1,102},
|
||||
{2, 423, 41, 53,123,421,123},
|
||||
{1312,214, 5, 1, 23, 4, 5}
|
||||
**Выходные данные**
|
||||
{ 1, 2, 3, 4, 8, 10, 102},
|
||||
{421, 123, 2, 41, 423, 53, 123 },
|
||||
{ 4, 23, 1312, 5, 214, 1, 5}
|
||||
|
||||
#### Пример 2
|
||||
**Входные данные**
|
||||
{ 7, 12, 5, 2, 98, 33, 9},
|
||||
{ 45, 3, 67, 89, 1, 4, 8},
|
||||
{200, 50, 150, 25, 175, 75, 5}
|
||||
**Выходные данные**
|
||||
{ 2, 5, 7, 9, 12, 33, 98 },
|
||||
{ 89, 67, 45, 8, 3, 4, 1 },
|
||||
{ 25,150, 200, 5, 50, 75, 175 }
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user