![]() | Ім'я файлу: СПЗ_ЛАБ_1.docx Розширення: docx Розмір: 161кб. Дата: 07.06.2022 скачати Пов'язані файли: 5.docx Лаба 4_РТП_СЗІ_Кліщ Богдан.docx Лаба 5_РТП_СЗІ_Кліщ.docx Тести, статистика праці.docx Реферат Лесько П.В. Авторське право ЕЛЕП-11.docx.doc Індивідуальна нормативне.docx lab2.docx ЦЕРКВА РІЗДВА ПРЕСВЯТОЇ БОГОРОДИЦІ У САМБОРІ.docx ШАБЕЛЬКО КУРСОВА.docx Розраха.docx Сучасні методики здорового харчування.docx Звіт до БД 2.docx звіт_від_ред.docx lab_8_Kravets.docx Сєрий.docx Сенсорне виховання.doc lab5_бд.docx Фізика5 Моя лаба.doc Вебинар англ.docx 5.docx ЛР 3 ФДП.docx Методичка до ПЗ №5-6.doc зразок РГР 2021 (1).docx курсова 1.docx Міністерство_освіти_та_науки_України_PI.docx Контрольна робота Павло Коцаба.docx Метод Баркера.docx Grej_R._S.docx Міністерство освіти і науки України Національний університет «Львівська політехніка» Кафедра ЕОМ ![]() Звіт до лабораторної роботи № 1 з дисципліни: «Системне програмне забезпечення» «Процеси та потоки» Варіант №10 Виконав: ст.гр. КІ-35 Коротких А.М. Прийняв: Пищак І.І. Львів 2022 Мета роботи: Засвоїти поняття «процесів» та «потоків» як основних компонентів сучасних операційних систем. Здобути навики створення, керування та знищення «процесів» та «потоків» в операційній системі Windows. Завдання на лабораторну роботу: 1. Розробити програму в середовищі Visual Studio, що демонструє використання системних викликів, відзначених символом “+”, відповідно до варіанту (таблиця 1). 10 номер в списку = 10 варіант. Таблиця 1 – Варіанти завдань
2. Написати функцію потоку, яка як вхідний параметр приймає дескриптор відкритого текстового файлу. Функція повинна здійснювати посимвольне виведення у файл номер процесу, номер потоку та системний час. Передбачити достатню кількість ітерації запису в файл з одної функції потоку. Відкриття файлу слід виконувати до створення потоку, використовуючи функцію FileOpen(), а після завершення роботи з файлом слід викликати функцію FileClose(). 3. Щоб продемонструвати паралельне виконання створеного потоку з первинним потоком процесу, в цикл запису з файлу потрібно додати виклик Sleep(Num), де Num – час в мілісекундах, на який слід призупинити виконання потоку. Затримку також можна організувати за допомогою лічильника до якогось досить великого числа. 4. Проаналізувати вміст файлу після завершення програми та порівняти записи при активному та пасивному очікуванні. Короткі теоретичні відомості. ShellExecute() - може не тільки запускати заданий додаток, але і відкривати документ, пов’язаний з цим додатком. Для того, щоб мати нагоду управляти створеним процесом в додатку слід використовувати виклик CreateProcess(). Коли в додатку викликається CreateProcess(), система створює об’єкт ядра "процес" з початковим значенням лічильника числа користувачів, рівним одиниці. Цей об’єкт — компактна структура даних, через яку операційна система управляє процесом. Далі система переходить до створення об’єкту ядра "потік" (з лічильником числа користувачів, рівним одиниці) для управління первинним потоком нового процесу. Якщо системі вдається створити новий процес і його первинний потік, функція повертає TRUE. Щоб мати нагоду використовувати перераховані функції управління процесом, необхідний відповідний рівень доступу до дескриптора процесу. Цей рівень доступу можна отримати застосувавши функцію OpenProcess(). Ця функція використовується також отримання дескриптора вже створеного процесу по відомому ідентифікатору. Отримати ідентифікатор процесу можна за допомогою функції GetCurrentProcessId(). Коли відпадає необхідність у використовуванні об’єктів ядра "потік" і "процес" необхідно з потоків, що їх створили, викликати функцію CloseHandle(). Тим самим зменшується лічильник числа їх користувачів на 1. При досягненні лічильником нуля об’єкти видаляються системою. Звичайно процес створюється з класом пріоритету normal. Отримати клас пріоритету процесу можна використовуючи функцію GetPriorityClass(). Змінити клас пріоритету процесу можна функцією SetPriorityClass(). Щоб визначити момент завершення потоку, використовується виклик GetExitCodeThread(). Цей виклик повертає або значення STILL_ACTIVE (якщо потік все ще продовжує роботу), або код завершення потоку. Для завершення потоку використовуються виклики _endthreadex() або TerminateThread().Функція TerminateThread() дозволяє завершити будь-який потік. Для збільшення або зменшення швидкості виконання потоку (точніше за програмний код, який він реалізує) потрібно відповідно міняти його пріоритет, використовуючи функцію SetThreadPriority(). Отримати рівень пріоритету потоку можна функцією GetThreadPriority() Код програми: #include #include #include #include #include #include using namespace std; static fstream f; static unsigned __stdcall ThreadFunc(void* num) { for (int i = 0; i < 0x06; i++) { f << GetTickCount() << endl;// запис у файл Sleep(2); } return 0; } int Func_Lab_1(HANDLE hProc) { time_t current_time; time(¤t_time); f.open("D:\lab1.txt"); f << "Current Date and time is: \n"; f << ctime(¤t_time) << "\n"; f << "Process number: \n"; f << GetCurrentProcessId() << "\n"; f << "Number flow: \n"; f << GetCurrentThreadId(); f.close(); //Відкриваємо редактор ShellExecute(NULL, "open", "notepad.exe", "D:\lab1.TXT", NULL, SW_SHOW); return 0; } void main() { //Відкриваємо редактор ShellExecuteW(0, L"open", L"C:\\Windows\\notepad.exe", 0, 0, SW_RESTORE); cout << "ShellExecute: " << ShellExecuteW(0, L"open", L"C:\\Windows\\notepad.exe", 0, 0, SW_RESTORE) << endl; HANDLE hProc = 0;//Тут буде зберігаєтися дескриптор відкритого процесу STARTUPINFOW siStartupInfo;//Тут містяться дані про відкриття процесу PROCESS_INFORMATION piProcessInfo;//Тут зберігаються дані про процес memset(&siStartupInfo, 0, sizeof(siStartupInfo));//"заливаємо" нулями структури для роботи процесу memset(&piProcessInfo, 0, sizeof(piProcessInfo)); siStartupInfo.cb = sizeof(siStartupInfo);//записуємо розмір структури //Запускаємо власний процес з exe-файлу на диску CreateProcessW(L"C:\\Windows\\notepad.exe", 0, 0, 0, false, 0, 0, 0, &siStartupInfo, &piProcessInfo); cout << "CreateProcess: " << CreateProcessW(L"C:\\Windows\\notepad.exe", 0, 0, 0, false, 0, 0, 0, &siStartupInfo, &piProcessInfo) << endl; hProc = OpenProcess(PROCESS_ALL_ACCESS, false, piProcessInfo.dwProcessId);//"Влазимо" у відкритий нами процеc cout << "OpenProcess: " << OpenProcess(PROCESS_ALL_ACCESS, false, piProcessInfo.dwProcessId) << endl; //виводимо на екран викликаного процесу Sleep(3000);//Показуємо, що ми на 3 секунди відкрили блокнот cout << "Priority1: " << GetPriorityClass(hProc) << endl; SetPriorityClass(hProc, IDLE_PRIORITY_CLASS); cout << "Priority2: " << GetPriorityClass(hProc) << "\n" << endl; cout << "Terminate2: " << TerminateProcess(hProc, 0) << "\n" << endl; GetCurrentProcessId();//ідентифікатор процесу cout << "ProcessId: " << GetCurrentProcessId() << "\n" << endl;//виводимо ідентифікатор процесу Sleep(100);//Чекаємо на "вбивство" процесу CloseHandle(piProcessInfo.hProcess);//закриваємо дескриптор процесу CloseHandle(piProcessInfo.hThread);//закриваємо дескриптор потоків нашого процесу Func_Lab_1(hProc); ////Потоки HANDLE hThread = NULL; unsigned int ThreadId = NULL; DWORD ThreadExit = NULL; f.open("output.txt", ios::out);//відкриваємо дескриптор файлу hThread = (HANDLE)_beginthreadex(NULL, 0, ThreadFunc, NULL, NULL, &ThreadId); cout << "_beginthreadex: " << _beginthreadex(NULL, 0, ThreadFunc, NULL, NULL, &ThreadId) << "\n" << endl; _endthreadex(0);//вбиваємо потік cout << "Priority before: " << GetThreadPriority(hThread) << endl;//Дістаємо пріоритет потоку до встановлення SetThreadPriority(hThread, THREAD_PRIORITY_HIGHEST);//Встановлюємо пріоритет потоку cout << "Priority after: " << GetThreadPriority(hThread) << endl;//Дістаємо пріоритет потоку після встановлення Sleep(1000); cout << "TickCount: " << endl; for (int i = 0; i < 0x06; i++) cout << GetTickCount() << endl; Sleep(1000); //даємо час потоку завершитись TerminateThread(hThread, 0); CloseHandle(hThread); cout << "Exit Code of Thread: " << ThreadExit << endl; f.close(); system("pause"); } Виконання: ![]() ![]() Рис.1. Результати виконання програми. Висновок: на лабораторній роботі засвоєно поняття «процесів» та «потоків» як основних компонентів сучасних операційних систем. |