Тема: «Процеси та потоки»
Мета: Засвоїти поняття «процесів» та «потоків» як основних компонентів сучасних операційних систем. Здобути навики створення, керування та знищення «процесів» та «потоків» в операційній системі 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(<);
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(<);
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(<);
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