Лабораторна №1

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

ВУЗ:
Інші
Інститут:
Не вказано
Факультет:
УІ
Кафедра:
Не вказано

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

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

Частина тексту файла (без зображень, графіків і формул):

Тема: «Процеси та потоки» Мета: Засвоїти поняття «процесів» та «потоків» як основних компонентів сучасних операційних систем. Здобути навики створення, керування та знищення «процесів» та «потоків» в операційній системі Windows. Завдання: 1. Розробити програму в середовищі Visual Studio, що демонструє використання системних викликів, відзначених символом “+”, відповідно до варіанту (таблиця 4) Системний виклик Варіант   5  WinExec +  ShellExecute   CreateProcess +  OpenProcess +  GetCurrentProcessId   CloseHandle +  GetExitCodeProcess +  TerminateProcess +  GetPriorityClass +  SetPriorityClass   _beginthreadex +  _endthreadex +  GetExitCodeThread   TerminateThread +  SetThreadPriority   GetThreadPriority   SuspendThread +  ResumeThread +   2. Написати функцію потоку, яка як вхідний параметр приймає дескриптор відкритого текстового файлу. Функція повинна здійснювати посимвольне виведення у файл номер процесу, номер потоку та системний час. Передбачити достатню кількість ітерації запису в файл з одної функції потоку. Відкриття файлу слід виконувати до створення потоку, використовуючи функцію FileOpen(), а після завершення роботи з файлом слід викликати функцію FileClose(). 3. Щоб продемонструвати паралельне виконання створеного потоку з первинним потоком процесу, в цикл запису з файлу потрібно додати виклик Sleep(Num), де Num – час в мілісекундах, на яке слід призупинити виконання потоку. Затримку також можна організувати за допомогою лічильника до якогось досить великого числа. 4. Проаналізувати вміст файлу після завершення програми та порівняти записи при активному та пасивному очікуванні. Текст програми: #include "stdafx.h" #include "windows.h" #include "conio.h" #include "stdlib.h" #include "process.h" # include <ShellAPI.h> static unsigned __stdcall ThreadFunc(void *file) { SYSTEMTIME lt; char buffer2[20]; char *r,*kS1; GetLocalTime(&lt); FILE *file1 = (FILE *) file; long int l = GetCurrentProcessId(); int m; for(int j = 1; j < 21; j++){ Sleep(170); printf("NewThread : %d ms\n",j*100);} for (int i=0;i<10;i++) { Sleep(10); r=ltoa(l,buffer2,10); fputs("Potik2 ",file1); fputs(r,file1); fputs(" ",file1); GetLocalTime(&lt); m=lt.wMinute; kS1=itoa(m,buffer2,10); fputs(kS1,file1); m=lt.wSecond; kS1=itoa(m,buffer2,10); fputs(":",file1); fputs(kS1,file1); m=lt.wMilliseconds; kS1=itoa(m,buffer2,10); fputs(":",file1); fputs(kS1,file1); fputs("",file1); } int out=0; while(out!=5) scanf("%d",&out); if (out==5) _endthreadex(0); return 0; } int _tmain(int argc, _TCHAR* argv[]) { SYSTEMTIME lt; FILE *file; HWND Handl=0; HANDLE hProc; unsigned ThreadId; HANDLE hThread; DWORD dEXc; dEXc=0; char buffer[20]; char *p; char *kS; int TPrior; int Stan; printf("Zapustumo fail proektu Visual Studio"); getch(); WinExec("calc.exe",SW_RESTORE); // запускає процес getch(); STARTUPINFO SProcess; PROCESS_INFORMATION ProcInfo; ZeroMemory(&SProcess,sizeof(SProcess)); SProcess.cb = sizeof(SProcess); printf("\nStvorumo proces Internet Explorer"); getch(); CreateProcess(L"C:\\Program Files\\Internet Explorer\\IEXPLORE.EXE", NULL,NULL,NULL,FALSE,0,NULL,NULL,&SProcess,&ProcInfo); getch(); printf("\nCreate process handle\n"); HANDLE hdl; //Вказівник на процес hdl = OpenProcess(PROCESS_ALL_ACCESS,FALSE,ProcInfo.dwProcessId); // звязує вказівник з процесом, і задає доступ до пріоритету getch(); DWORD Exit; GetExitCodeProcess(hdl,&Exit); // Чи запущений рпроцес, в Exit записується код роботи процесу printf("Exit Code: %x\n",Exit); if (Exit == STILL_ACTIVE) printf ("process is running\n"); else printf ("process isn't running\n"); getch(); DWORD PriorityClass; PriorityClass = GetPriorityClass(hdl); // Повертає пріоритет процесу printf("Priority Class: %x\n",PriorityClass); getch(); printf("Close proccess\n"); TerminateProcess(hdl,0); // Закриває процес getch(); printf("Close proccess handle\n"); CloseHandle(hdl); //Видаляє хендл getch(); HANDLE hFile; DWORD dwExitCode; file = fopen( "C:\\1.txt", "w" ); hThread=(HANDLE)_beginthreadex(NULL, 0, &ThreadFunc, &(*file), NULL, &ThreadId); printf("Create new Thread\n"); printf("Main thread will sleep for 1 sec\n"); Sleep(1000); printf("Stop new Thread\n"); SuspendThread(hThread); // призупинити виконання потоку printf("Main thread : \n"); for(int i = 1; i < 6; i++ ){ Sleep(100); printf("Main thread : %d ms\n",i*100); } getch(); printf("Resume new Thread\n"); ResumeThread(hThread); //Відновити виконання потоку for(int i = 6; i < 12; i++ ){ Sleep(100); printf("Main thread : %d ms\n",i*100); } getch(); printf("Close new Thread\n"); TerminateThread(hThread,0); // Закрити потік printf("Close Thread handle\n"); CloseHandle(hThread); //Закрити хендл потоку printf ("End program\n"); long int k = GetCurrentProcessId(); int m; for (int i=0;i<10;i++) { Sleep(10); p=ltoa(k,buffer,10); fputs("Potik1 ",file); fputs(p,file); fputs(" ",file); GetLocalTime(&lt); m=lt.wMinute; kS=itoa(m,buffer,10); fputs(kS,file); m=lt.wSecond; kS=itoa(m,buffer,10); fputs(":",file); fputs(kS,file); m=lt.wMilliseconds; kS=itoa(m,buffer,10); fputs(":",file); fputs(kS,file); fputs("",file); } fclose( file ); getch(); return 0; } Вікно програми результату: Результат виконання програми з Sleep(): Potik2 3264 49:36:955Potik2 3264 49:36:965Potik2 3264 49:36:975Potik2 3264 49:36:985Potik2 3264 49:36:995Potik2 3264 49:37:5Potik2 3264 49:37:15Potik2 3264 49:37:25Potik2 3264 49:37:35Potik2 3264 49:37:45Potik1 3264 49:37:498Potik1 3264 49:37:508Potik1 3264 49:37:518Potik1 3264 49:37:528Potik1 3264 49:37:538Potik1 3264 49:37:548Potik1 3264 49:37:558Potik1 3264 49:37:568Potik1 3264 49:37:578Potik1 3264 49:37:588 Висновок. В даній лабораторній роботі я засвоїла поняття «процесів» та «потоків», як основних компонентів сучасних операційних систем. Здобула навики створення, керування та знищення «процесів» та «потоків» в операційній системі Windows
Антиботан аватар за замовчуванням

15.12.2013 19:12-

Коментарі

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

Ділись своїми роботами та отримуй миттєві бонуси!

Маєш корисні навчальні матеріали, які припадають пилом на твоєму комп'ютері? Розрахункові, лабораторні, практичні чи контрольні роботи — завантажуй їх прямо зараз і одразу отримуй бали на свій рахунок! Заархівуй всі файли в один .zip (до 100 МБ) або завантажуй кожен файл окремо. Внесок у спільноту – це легкий спосіб допомогти іншим та отримати додаткові можливості на сайті. Твої старі роботи можуть приносити тобі нові нагороди!
Нічого не вибрано
0%

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

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

Подякувати Студентському архіву довільною сумою

Admin

26.02.2023 12:38

Дякуємо, що користуєтесь нашим архівом!