МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ
НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ «ЛЬВІВСЬКА ПОЛІТЕХНІКА»
ЗВІТ
До лабораторної роботи №4
з курсу: «Операційні системи»
на тему: «Багатопотокове програмування в сучасних ОС»
Варіант - 10
Мета: ознайомлення з поняттям багатопотоковості в сучасних операційних системах, отримання практичних навичок створення багато потокових застосувань в середовищі Visual Studio C#.
Короткі теоретичні відомості
Як відомо [1] потоком (потік керування, нитка, thread) називають набір послідовно виконуваних команд процесора, які використовують загальний адресний простір процесу. Оскільки в системі може одночасно бути багато потоків, завданням ОС є організація перемикання процесора між ними і планування їхнього виконання. У багатопроцесорних системах код окремих потоків може виконуватися на окремих процесорах.
Багатопотоковими називають програми, які одночасно виконують різні чи однотипні завдання, використовуючи при тому декілька потоків.
Розглянемо яким чином можна оптимізувати програми, використовуючи багатопотоковість.
Але не завжди можна розпаралелити задачу. Не завжди є в тому сенс. Наприклад, якщо у нас є один потік даних і його необхідно обробляти в певному порядку, і при цьому без результатів попередньої обробки даних наступну операцію виконувати не можна, то в такій програмі створення додаткових потоків нічого нам не дасть.
Потоки не повинні заважати один одному і повинні використовувати ефективно ресурси системи, в якій вони працюють.
Завдання:
Вивчити теоретичний матеріал, що стосується методів та засобів багатопотоковості в C#.
Побудувати алгоритм програми, яка вирішує завдання оптимізації виконання певних операцій над матрицями з використанням багатопотоковості. Завдання наведені в таблиці відповідно до варіанту.
Використовуючи засоби Visual Studio (C#, C++, …) створіть програму, що вирішує дане завдання (в консольному чи WinForms режимі).
Проведіть тестування створеної програми.
Для 10-х варіантів довільних даних проведіть обчислення.
Результати обчислення наведіть у висновку.
В звіті по лабораторної роботи відобразити:
- теоретичний огляд;
- зміст завдання;
- блок-схему алгоритму;
- текст програми у вигляді таблиці результати роботи для 10-ти варіантів даних.
Індивідуальне завдання (згідно варіанту)
10
Кількість потоків: 3
Сума 2-х матриць (3х3)
Текст програми:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
lab4 os = new lab4();
os.create();
os.vuvidAB();
Thread p1 = new Thread(new ThreadStart(os.potik1));
p1.Start(); Thread.Sleep(10);
Thread p2 = new Thread(new ThreadStart(os.potik2));
p2.Start(); Thread.Sleep(10);
Thread p3 = new Thread(new ThreadStart(os.potik3));
p3.Start(); Thread.Sleep(10);
os.rezultat();
Console.ReadKey();
}
}
class lab4
{
public int[,] A;
public int[,] B;
public int[,] Rez;
public void create()
{
A = new int[3, 3];
B = new int[3, 3];
Rez = new int[3, 3];
Random random = new Random();
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
A[i, j] = random.Next(0, 10);
B[i, j] = random.Next(0, 10);
}
}
}
public void potik1()
{
int i = 0;
for (int j = 0; j < 3; j++)
{
Rez[i, j] = A[i, j] + B[i, j];
}
}
public void potik2()
{
int i = 1;
for (int j = 0; j < 3; j++)
{
Rez[i, j] = A[i, j] + B[i, j];
}
}
public void potik3()
{
int i = 2;
for (int j = 0; j < 3; j++)
{
Rez[i, j] = A[i, j] + B[i, j];
}
}
public void vuvidAB()
{
Console.WriteLine("Матриця A:");
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
Console.Write("\t" + A[i, j]);
}
Console.Write("\n");
}
Console.WriteLine("Матриця B:");
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
Console.Write("\t" + B[i, j]);
}
Console.Write("\n");
}
}
public void rezultat()
{
Console.WriteLine("Матриця Rezultat:");
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
Console.Write("\t" + Rez[i, j]);
}
Console.Write("\n");
}
}
}
}
Результат виконання програми
/
Висновок
Під час цієї лабораторної роботи я ознайомилась з поняттям багатопотоковості в сучасних операційних системах, отримав практичні навички створення багатопотокових застосувань в середовищі Visual Studio C#.