Курсовая работа: Розробка програмного забезпечення системи збору даних про хід та параметри технологічного процесу
if (ret == SOCKET_ERROR)
{
bConnect = 1;
break;
}
nLeft -= ret;
idx += ret;
}
}//if
Програма буде працювати так постійно, доки користувач не закриє форму програми. Ця подія перехопиться і цикл завершиться, також закриються сокети та поток програми.
7. Програмне забезпечення серверу
Інтерейс серверу зображено на рисунку 6.1.
Рисунок 6. 1 – Інтерфейс серверу
Спочатку користувач вводит адрес серверу, а потім запускає його. Після цього кнопка стане неактивованою.
Сервер також використовую блокуючи сокети. Це приводить до того, що необхідно створювати нові потоки для кожної блокуючої функції. Це з одного боку спрощує роботу з самими сонетами, але ускладнює задачу взаємодії потоків, коли вони використовують одні й ті ж змінні, коли один потік закриваює інший. Велика кількість потоків прискорює роботу серверу на багатопроцесорних системах, але загальмовує її на одно процесорних, бо операційній системі необхідно перемикатися між задачами.
Сервер має постійним потік прийому сокетів та контролю таймаутій. Також програма створює новий потік для кожного клієнта.
Алгоритм прийому клієнтів має наступний вигляд:
while (1)
{
sockAccept = accept(sListen, NULL, NULL);
if ((sockAccept == INVALID_SOCKET) && (WSAGetLastError() == WSAENOTSOCK))
break;
EnterCriticalSection (&cs);
if ((sockAccept != INVALID_SOCKET) && (iNumClients < MAX_CLIENT ))
{
sockInfo[iNumClients].sClient = sockAccept;
sockInfo[iNumClients].typeSender = 0;
sockInfo[iNumClients].time = time(NULL);