Студопедия
Новини освіти і науки:
МАРК РЕГНЕРУС ДОСЛІДЖЕННЯ: Наскільки відрізняються діти, які виросли в одностатевих союзах


РЕЗОЛЮЦІЯ: Громадського обговорення навчальної програми статевого виховання


ЧОМУ ФОНД ОЛЕНИ ПІНЧУК І МОЗ УКРАЇНИ ПРОПАГУЮТЬ "СЕКСУАЛЬНІ УРОКИ"


ЕКЗИСТЕНЦІЙНО-ПСИХОЛОГІЧНІ ОСНОВИ ПОРУШЕННЯ СТАТЕВОЇ ІДЕНТИЧНОСТІ ПІДЛІТКІВ


Батьківський, громадянський рух в Україні закликає МОН зупинити тотальну сексуалізацію дітей і підлітків


Відкрите звернення Міністру освіти й науки України - Гриневич Лілії Михайлівні


Представництво українського жіноцтва в ООН: низький рівень культури спілкування в соціальних мережах


Гендерна антидискримінаційна експертиза може зробити нас моральними рабами


ЛІВИЙ МАРКСИЗМ У НОВИХ ПІДРУЧНИКАХ ДЛЯ ШКОЛЯРІВ


ВІДКРИТА ЗАЯВА на підтримку позиції Ганни Турчинової та права кожної людини на свободу думки, світогляду та вираження поглядів



Лекция 3. Критерий сходимости последовательности. Подпоследовательности

Висновки

Особливості програмного інтерфейсу потоків

Створення потоків

 

Основним засобом створення потоків у Windows ХР є функція CreateThread() Win32 АРІ. Назвемо етапи виконання цієї функції.

1. В адресному просторі процесу створюють стек режиму користувача для потоку.

2. Ініціалізують апаратний контекст потоку (у процесор завантажують дані, що визначають його стан). Цей крок залежить від архітектури процесора.

3. Створюють об'єкт-потік виконавчої системи у призупиненому стані, для чого
в режимі ядра:

а) створюють та ініціалізують структури даних потоку (блоки ETHREAD,
KTHREAD, ТЕВ);

б) задають стартову адресу потоку (використовуючи передану як параметр
адресу процедури потоку);

в) задають інформацію для підсистеми безпеки та ідентифікатор потоку;

г) виділяють місце під стек потоку ядра.

4. Підсистемі Win32 повідомляють про створення нового потоку.

5. Дескриптор та ідентифікатор потоку повертають у процес, що ініціював ство­рення потоку (викликав CreateThreadO).

6. Починають виконання потоку (виконують перехід за стартовою адресою).

 

 

Програмний інтерфейс керування потоками у Windows ХР є частиною Win32 АРІ. Такий інтерфейс ще називають інтерфейсом потоків Win32. Розглянемо особли­вості його використання.

Створення потоків у Win32 АРІ

У Win32 АРІ, як зазначалося раніше, для створення потоку призначена функція CreateThread(), а для його завершення - EndThread().

На практиці, однак, пару CreateThread( )/EndThread() є сенс використати лише тоді, коли з коду, що виконує потік, не викликаються функції стандартної бібліо­теки мови С (такі, як printf О або strcmpO).

Річ у тому, що функції стандартної бібліотеки С у Win32 АРІ не пристосовані до використання за умов багатопотоковості, і для того щоб підготувати потік до роботи за таких умов, необхідно під час його створення і завершення виконувати деякі додаткові дії. Ці дії враховані у спеціальних бібліотечних функціях роботи з потоками, описаних у заголовному файлі process. h. Це функція _begi nthreadex() для створення потоку й _endthreadex() — для завершення потоку.

Після створення потоку може виникнути потреба змінити його характеристи­ки. Якщо це необхідно зробити у функції потоку, варто знати, як отримати доступ до його дескриптора.

 

♦ Процеси і потоки є активними ресурсами обчислювальних систем, які реалі­зують виконання програмного коду. Потоком називають набір послідовно ви­конуваних команд процесора. Процес є сукупністю одного або декількох по­токів і захищеного адресного простору, в якому вони виконуються. Потоки одного процесу можуть разом використовувати спільні дані, для потоків різних процесів без використання спеціальних засобів це неможливо. У традиційних системах кожний процес міг виконувати тільки один потік, виконання про­грамного коду пов'язували із процесами. Сучасні ОС підтримують концепцію багатопотоковості.

♦ Використання потоків у застосуванні означає внесення в нього паралелізму -можливості одночасного виконання дій різними фрагментами коду. Парале­лізм у програмах відображає асинхронний характер навколишнього світу, його джерелами є виконання коду на декількох процесорах, операції введення-виведення, взаємодія з користувачем, запити застосувань-клієнтів. Багато-потоковість у застосуваннях дає змогу природно реалізувати цей паралелізм і домогтися високої ефективності. З іншого боку, використання багатопотоко­вості досить складне і вимагає високої кваліфікації розробника.

♦ Розрізняють потоки користувача, які виконуються в режимі користувача в адрес­ному просторі процесу, і потоки ядра, з якими працює ядро ОС. Взаємовідно­шення між ними визначають схему реалізації моделі потоків. На практиці найчастіше використовують схему 1:1, коли кожному потоку користувача відпо­відає один потік ядра, і саме ядро відповідає за керування потоками користувача.

♦ Потік може перебувати в різних станах (виконання, очікування, готовності тощо). Принципи переходу з одного стану в інший залежать від принципів пла­нування потоків і планування процесорного часу. Перехід процесу зі стану ви­конання у будь-який інший стан зводиться до перемикання контексту — пере­дачі керування від одного потоку до іншого зі збереженням стану процесора.

♦ Кожному процесу і потоку в системі відповідає його керуючий блок - струк­тура даних, що містить усю необхідну інформацію. Під час створення процесу (зазвичай за допомогою системного виклику fork ( ) створюють його керую­чий блок, виділяють пам'ять і запускають основний потік. Створення потоку простіше і виконується швидше, оскільки не потрібно виділяти пам'ять під новий адресний простір.

 


Читайте також:

  1. Компетентностный подход как базовый критерий оценки качества образования.
  2. ЛЕКЦИЯ 1
  3. Лекция 1
  4. Лекция 1.
  5. Лекция 1.
  6. Лекция 1. Введение
  7. Лекция 1. Векторная графика. Macromedia Flash MX Инструменты и технологии рисования во Flash
  8. Лекция 1. МАКРОЭКОНОМИКА. НАЦИОНАЛЬНАЯ
  9. ЛЕКЦИЯ 10
  10. Лекция 10.
  11. Лекция 11. Растворы электролитов. Электролитическая
  12. Лекция 11. Растворы электролитов. Электролитическая




Переглядів: 702

<== попередня сторінка | наступна сторінка ==>
Структури даних потоку | Висновок.

Не знайшли потрібну інформацію? Скористайтесь пошуком google:

  

© studopedia.com.ua При використанні або копіюванні матеріалів пряме посилання на сайт обов'язкове.


Генерація сторінки за: 0.014 сек.