2025-02-27 22:16:07 +04:00
# Лабораторная №1
Разработка многопоточного приложения с использованием Java Concurrency
согласно варианту задания.
Необходимо:
1 Разработать однопоточный вариант алгоритма и замерить время е г о работы.
2 Разработать параллельный вариант алгоритма с использованием
ThreadPoolExecutor и замерить время е г о работы
3 Разработать параллельный вариант алгоритма с использованием ForkJoinPoll
и замерить время е г о работы.
ВАЖНО: Массив генерируется до работы всех вариантов алгоритмов. В с е три
алгоритма обрабатывают три одинаковых массива.
## Вариант и задание
17 Упорядочить строки матрицы по убыванию суммы элементов.
### Описание
2025-02-23 21:36:57 +04:00
Данная программа разработана для сравнения производительности однопоточного и многопоточного подходов к сортировке строк матрицы по убыванию суммы их элементов. Задача состоит из двух основных частей:
2025-02-27 22:16:07 +04:00
1. **Подсчёт сумм строк** : Для каждой строки матрицы вычисляется сумма её элементов.
2. **Сортировка строк** : Строки матрицы сортируются по убыванию суммы их элементов.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
Эти этапы выполняются с разными вариантами многопоточности, чтобы выявить их влияние на производительность при различных размерах матрицы.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Как запустить
```sh
2025-02-23 21:36:57 +04:00
javac MatrixSorter.java
java MatrixSorter
2025-02-27 22:16:07 +04:00
```
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Используемые технологии
Программа использует **Java Concurrency** , включая классы и интерфейсы:
- `ExecutorService` , `ThreadPoolExecutor` , `ForkJoinPool` , `Future` , `CompletableFuture` , `RecursiveAction` — для организации многопоточности.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Что делает программа
1. Генерирует матрицу заданного размера, заполненную случайными значениями.
2. Вычисляет сумму элементов каждой строки.
3. Сортирует строки по убыванию их суммы.
4. Замеряет среднее время выполнения разных комбинаций подсчёта и сортировки.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
---
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
## Анализ результатов
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Результаты в файле res.txt
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Маленькие матрицы (10 x 1000000, 100 x 100000)
- Использование многопоточности не даёт значительного прироста, так как оверхед на создание потоков превышает выгоду от распараллеливания.
- `ThreadPool` или `ForkJoin` для сортировки могут даже слегка ухудшать производительность из-за накладных расходов.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Средние матрицы (1000 x 10000, 10000 x 1000)
- Н а этом размере многопоточное суммирование (`ThreadPool` , `ForkJoin` ) начинает давать выгоду.
- `ForkJoin` работает стабильно, а `ThreadPool` может давать как ускорение, так и замедление.
- Н а сортировке многопоточность помогает, но эффект зависит от формы матрицы.
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Большие матрицы (100000 x 100, 1000000 x 10)
- Однопоточное выполнение становится крайне неэффективным.
- `ForkJoin` даёт лучшие результаты как при подсчёте, так и при сортировке.
- `ThreadPool` работает лучше однопоточного подхода, но хуже `ForkJoin` .
2025-02-23 21:36:57 +04:00
2025-02-27 22:16:07 +04:00
### Выводы
1. **Для маленьких матриц** : Однопоточное выполнение предпочтительнее, так как накладные расходы на многопоточность не окупаются.
2. **Для средних матриц** : Подсчёт можно распараллеливать (`ForkJoin` предпочтителен), сортировка зависит от формы матрицы.
3. **Для больших матриц** : Использование `ForkJoin` даёт наилучший результат как для подсчёта, так и для сортировки.
4. **Использование `ThreadPool`** может быть полезно, но е г о эффективность зависит от конкретных размеров матрицы.
2025-02-23 21:36:57 +04:00