Адміністрація вирішила продати даний сайт. За детальною інформацією звертайтесь за адресою: rozrahu@gmail.com

Взаємодія

Інформація про навчальний заклад

ВУЗ:
Національний університет Львівська політехніка
Інститут:
Не вказано
Факультет:
КН
Кафедра:
Кафедра ЕОМ

Інформація про роботу

Рік:
2024
Тип роботи:
Лабораторна робота
Предмет:
Системне програмне забезпечення

Частина тексту файла

МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ “ЛЬВІВСЬКА ПОЛІТЕХНІКА” КАФЕДРА ЕОМ  Лабораторна робота №2 з курсу “ Системне програмне забезпечення” ВАРІАНТ 4 Тема: Взаємодія між потоками. Мета: Засвоїти поняття паралельного виконання «потоків» та освоїти засоби їх синхронізації. Здобути навики синхронізації «потоків» при обробці спільних даних та доступу до ресурсів в операційній системі Windows. Теоретична частина: Windows надає чотири об’єкти, призначені для синхронізації потоків і процесів. Три з них — мютекси, семафори і події — є об’єктами ядра, що мають дескриптори. Події використовуються також для інших цілей, наприклад, для асинхронного уведення-виведення. Спочатку розглянемо четвертий об’єкт, а саме, об’єкт критичної ділянки коду CRITICAL_SECTION. Через простоту і продуктивність, об’єктам критичних ділянок коду надається перевага, якщо їх можливостей достатньо для того, щоб задовольнити вимоги програміста. Об’єкт критичної ділянки коду — це ділянка програмного коду, який кожного разу повинен виконуватися тільки одним потоком; паралельне виконання цієї ділянки декількома потоками може приводити до непередбачуваних або невірних результатів. Об’єкти CRITICAL_SECTION (CS) можна ініціалізувати і видаляти, але вони не мають дескрипторів і не можуть спільно використовуватися іншими процесами. Відповідні змінні повинні оголошуватися як змінні типу CRITICAL_SECTION. Потоки входять в об’єкти CS і покидають їх, але виконання коду окремого об’єкту CS кожного разу дозволено тільки одному потоку. Разом з тим, один і той же потік може входити в декілька окремих об’єктів CS і покидати їх, якщо вони розташовані в різних місцях програми. Завдання: 1. Дослідити роботу програми в середовищі Visual Studio, що демонструє використання об’єктів критичних ділянок коду 2. Відповідно до варіанту модифікувати програму так, щоб замінити об’єкти синхронізації заданого числа потокі (Critical Section – 3, Semaphores – 4); 3. Проаналізувати та пояснити вміст дисплею після завершення програми. ТЕКСТ ПРОГРАМИ: #include "EvryThng.h" #include <time.h> #define DATA_SIZE 256 typedef struct msg_block_tag { /* Message block */ volatile DWORD f_ready, f_stop; /* ready state flag, stop flag */ volatile DWORD sequence; /* Message block sequence number */ volatile DWORD nCons, nLost; time_t timestamp; CRITICAL_SECTION mguard; /* Guard the message block structure */ DWORD checksum; /* Message contents checksum */ DWORD data[DATA_SIZE]; /* Message Contents */ } MSG_BLOCK; MSG_BLOCK mblock = { 0, 0, 0, 0, 0 }; HANDLE sema_h; unsigned int WINAPI produce(void *); unsigned int WINAPI consume(void *); unsigned int WINAPI WriteFunc(void *); unsigned int WINAPI ReadFunc(void *); void MessageFill(MSG_BLOCK *); void MessageDisplay(MSG_BLOCK *); int value = 0; unsigned uThreadIDs[4]; HANDLE hThreads[4]; DWORD _tmain(DWORD argc, LPTSTR argv[]) { unsigned int Status, ThId; HANDLE produce_h, consume_h; sema_h = CreateSemaphore(NULL, 0, 1000, NULL); hThreads[0] = (HANDLE)_beginthreadex(NULL, 0, ReadFunc, NULL, 0, &uThreadIDs[0]); hThreads[1] = (HANDLE)_beginthreadex(NULL, 0, WriteFunc, NULL, 0, &uThreadIDs[1]); hThreads[2] = (HANDLE)_beginthreadex(NULL, 0, ReadFunc, NULL, 0, &uThreadIDs[2]); hThreads[3] = (HANDLE)_beginthreadex(NULL, 0, WriteFunc, NULL, 0, &uThreadIDs[3]); /* Initialize the message block CRITICAL SECTION */ InitializeCriticalSection(&mblock.mguard); /* Create the two threads */ produce_h = (HANDLE)_beginthreadex(NULL, 0, produce, NULL, 0, &ThId); consume_h = (HANDLE)_beginthreadex(NULL, 0, consume, NULL, 0, &ThId); /* Wait for the producer and consumer to complete */ Status = WaitForSingleObject(consume_h, INFINITE); Status = WaitForSingleObject(produce_h, INFINITE); DeleteCriticalSection(&mblock.mguard); WaitForMultipleObjects(4, hThreads, TRUE, INFINITE); // без тайм-аута CloseHandle(sema_h); CloseHandle(hThreads[0]); CloseHandle(hThreads[1]); CloseHandle(hThreads[2]); CloseHandle(hThrea...
Антиботан аватар за замовчуванням

29.05.2018 23:05

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Завантаження файлу

Якщо Ви маєте на своєму комп'ютері файли, пов'язані з навчанням( розрахункові, лабораторні, практичні, контрольні роботи та інше...), і Вам не шкода ними поділитись - то скористайтесь формою для завантаження файлу, попередньо заархівувавши все в архів .rar або .zip розміром до 100мб, і до нього невдовзі отримають доступ студенти всієї України! Ви отримаєте грошову винагороду в кінці місяця, якщо станете одним з трьох переможців!
Стань активним учасником руху antibotan!
Поділись актуальною інформацією,
і отримай привілеї у користуванні архівом! Детальніше

Оголошення від адміністратора

Антиботан аватар за замовчуванням

пропонує роботу

Admin

26.02.2019 12:38

Привіт усім учасникам нашого порталу! Хороші новини - з‘явилась можливість кожному заробити на своїх знаннях та вміннях. Тепер Ви можете продавати свої роботи на сайті заробляючи кошти, рейтинг і довіру користувачів. Потрібно завантажити роботу, вказати ціну і додати один інформативний скріншот з деякими частинами виконаних завдань. Навіть одна якісна і всім необхідна робота може продатися сотні разів. «Головою заробляти» продуктивніше ніж руками! :-)

Новини