69301

Багатопотоковість та її реалізація

Лекция

Информатика, кибернетика и программирование

Багатопотокове застосування може реалізувати цей вид паралелізму через створення нових потоків які виконуватимуться коли поточний потік очікує операції введеннявиведення. При цьому використання потоків дає можливість організувати паралельне обслуговування запитів...

Украинкский

2014-10-03

50 KB

20 чел.

Лекція № 5

Тема: Багатопотоковість та її реалізація

План

  1.  Поняття паралелізму
  2.  Види паралелізму
  3.  Переваги і недоліки багатопотоковості
  4.  Способи реалізації моделі потоків

Поняття паралелізму

Використання декількох потоків у застосуванні означає внесення в нього паралелізму (concurrency). Паралелізм — це одночасне (з погляду прикладного програміста) виконання дій різними фрагментами коду застосування. Така одночасність може бути реалізована на одному процесорі шляхом перемикання задач (випадок псевдопаралелізму), а може ґрунтуватися на паралельному виконанні коду на декількох процесорах (випадок справжнього паралелізму). Потоки абстрагують цю відмінність, даючи можливість розробляти застосування, які в однопроцесорних системах використовують псевдопаралелізм, а при доданні процесорів - справжній паралелізм (такі застосування масштабуються зі збільшенням кількості процесорів).

Види паралелізму

Можна виділити такі основні види паралелізму:

♦  паралелізм багатопроцесорних систем;

♦  паралелізм операцій введення-виведення;

паралелізм взаємодії з користувачем;

паралелізм розподілених систем.

Перший з них є справжнім паралелізмом, тому що у багатопроцесорних системах інструкції виконують декілька процесорів одночасно. Особливості використання такого паралелізму будуть розглянуті в розділі 20. Інші види паралелізму можуть виникати і в однопроцесорних системах тоді, коли для продовження виконання програмного коду необхідні певні зовнішні дії.

Паралелізм операцій введення-виведення

Під час виконання операції введення-виведення (наприклад, обміну даними із диском) низькорівневий код доступу до диска і код застосування не можуть виконуватись одночасно. У цьому разі застосуванню треба почекати завершення операції введення-виведення, звільнивши на цей час процесор. Природним вважається зайняти на цей час процесор інструкціями іншої задачі.

Багатопотокове застосування може реалізувати цей вид паралелізму через створення нових потоків, які виконуватимуться, коли поточний потік очікує операції введення-виведення. Так реалізується асинхронне введення-виведення, коли застосування продовжує своє виконання, не чекаючи на завершення операцій введення-виведення. У розділі 15 буде розглянуто організацію такого введення-виведення.

Паралелізм взаємодії з користувачем

Під час інтерактивного сеансу роботи користувач може виконувати різні дії із застосуванням (і очікувати негайної реакції на них) до завершення обробки попередніх дій. Наприклад, після запуску команди «друкування документа» він може негайно продовжити введення тексту, не чекаючи завершення друкування.

Щоб розв'язати це завдання, можна виділити окремі потоки для безпосередньої взаємодії із користувачем (наприклад, один потік може очікувати введення з клавіатури, інший — від миші, додаткові потоки - відображати інтерфейс користувача). Основні задачі застосування (розрахунки, взаємодія з базою даних тощо) у цей час виконуватимуть інші потоки.

Паралелізм розподілених застосувань

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

Переваги і недоліки багатопотоковості

Назвемо проблеми, які можуть бути вирішені за допомогою потоків.

♦ Використання потоків дає змогу реалізувати різні види паралелізму і дозволяє застосуванню масштабуватися із ростом кількості процесорів.

Для підтримки потоків потрібно менше ресурсів, ніж для підтримки процесів (наприклад, немає необхідності виділяти для потоків адресний простір).

Для обміну даними між потоками може бути використана спільна пам'ять (адресний простір їхнього процесу). Це ефективніше, ніж застосовувати засоби міжпроцесової взаємодії.

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

♦ Розробляти і налагоджувати багатопотокові програми складніше, ніж звичайні послідовні програми; досить часто впровадження багатопотоковості призводить до зниження надійності застосувань. Організація спільного використання адресного простору декількома потоками вимагає, щоб програміст мав високу кваліфікацію.

♦ Використання потоків може спричинити зниження продуктивності застосувань.

Переважно це трапляється в однопроцесорних системах (наприклад, у таких системах спроба виконати складний розрахунок паралельно декількома потоками
призводить лише до зайвих витрат на перемикання між потоками, кількість виконаних корисних інструкцій залишиться тією ж самою).

Переваги і недоліки використання потоків потрібно враховувати під час виконання будь-якого програмного проекту. Насамперед доцільно розглядати можливість розв'язати задачу в рамках моделі процесів. При цьому, однак, варто брати до уваги не лише поточні вимоги замовника, але й необхідність розвитку застосування, його масштабування тощо. Можливо, з урахуванням цих факторів використання потоків буде виправдане.

Способи реалізації моделі потоків

Перш ніж розглянути основні підходи до реалізації моделі потоків, дамо означення важливих понять потоку користувача і потоку ядра.

Потік користувача — це послідовність виконання команд в адресному просторі процесу. Ядро ОС не має інформації про такі потоки, вся робота з ними виконується в режимі користувача. Засоби підтримки потоків користувача надають спеціальні системні бібліотеки; вони доступні для прикладних програмістів у вигляді бібліотечних функцій. Бібліотеки підтримки потоків у наш час звичайно реалізують набір функцій, визначений стандартом POSIX (відповідний розділ стандарту називають POSIX.lb); тут прийнято говорити про підтримку потоків POSIX.

Потік ядра — це послідовність виконання команд в адресному просторі ядра. Потоками ядра управляє ОС, перемикання ними можливе тільки у привілейованому режимі. Є потоки ядра, які відповідають потокам користувача, і потоки, що не мають такої відповідності.

Співвідношення між двома видами потоків визначає реалізацію моделі потоків. Є кілька варіантів такої реалізації (схем багатопотоковості); розглянемо найважливіші з них (рис. 3.1).

Схема багатопотоковості М:1 (є найранішою) реалізує багатопотоковість винятково в режимі користувача. При цьому кожен процес може містити багато потоків користувача, однак про наявність цих потоків ОС не відомо, вона працює тільки із процесами. За планування потоків і перемикання контексту відповідає бібліотека підтримки потоків. Схема вирізняється ефективністю керування потоками (для цього немає потреби переходити в режим ядра) і не потребує для реалізації зміни ядра ОС. Проте нині її практично не використовують через два суттєвих недоліки, що не відповідають ідеології багатопотоковості. Схема М:1 не дає змоги скористатися багатопроцесорними архітектурами, оскільки визначити, який саме код виконуватиметься на кожному із процесорів, може тільки ядро ОС. У результаті всі потоки одного процесу завжди виконуватимуться на одному процесорі. +  Оскільки системні виклики обробляються на рівні ядра ОС, блокувальний системний виклик (наприклад, виклик, який очікує введення даних користувачем) зупинятиме всі потоки процесу, а не лише той, що зробив цей виклик.

Схема багатопотоковості 1:1 ставить у відповідність кожному потоку користувача один потік ядра. У цьому разі планування і перемикання контексту зачіпають лише потоки ядра, у режимі користувача ці функції не реалізовані. Оскільки ядро ОС має інформацію про потоки, ця схема вільна від недоліків попередньої (різні потоки можуть виконуватися на різних процесорах, а при зупиненні одного потоку інші продовжують роботу). Вона проста і надійна в реалізації і сьогодні є найпоширенішою. Хоча схема передбачає, що під час керування потоками треба постійно перемикатися між режимами процесора, на практиці втрата продуктивності внаслідок цього виявляється незначною.

Схема багатопотоковості M:N. У цій схемі присутні як потоки ядра, так і потоки користувача, які відображаються на потоки ядра так, що один потік ядра може відповідати декільком потокам користувача. Число потоків ядра може бути змінене програмістом для досягнення максимальної продуктивності. Розподіл потоків користувача по потоках ядра виконується в режимі користувача, планування потоків ядра — у режимі ядра. Схема є складною в реалізації і сьогодні здає свої позиції схемі 1:1.

Питання для самоконтролю:

  1.  Поняття паралелізму. Охарактеризувати види.
  2.  Переваги та недоліки багатопотоковості.
  3.  Потік користувача. Потік ядра.
  4.  Охарактеризувати схеми багатопотоковості.


 

А также другие работы, которые могут Вас заинтересовать

35442. Возрастные изменения структуры нейрона. Нервный центр. Рефлекс 13.72 KB
  Процесс созревания нейронов характеризуется быстрым увеличением цитоплазмы увеличением в ней числа рибосом и формированием аппарата Гольджи интенсивным ростом аксонов и дендритов. Созревание мелких клеток интеп нейронов происходит после рождения в постнатальном онто генезе под влиянием средовых факторов что создает предпосылки для пластических перестроек в центральной нервной системе. Нервный центр совокупность нервных клеток Нейронов более или менее строго локализованная в нервной системе и непременно участвующая в осуществлении...
35444. Проблемы административного расследования в таможенных органах в период реформирования таможенного законодательства 484.5 KB
  Объектом дипломного исследования являются общественные отношения, складывающиеся в процессе производства по делам об административных правонарушениях, связанные с проведением административного расследования, предметом - административное расследование в механизме производства по делам об административных правонарушениях.
35445. Хирургия. Шпаргалка 451 KB
  Предраковые заболевания толстой и прямой кишки. Дивертикулы дивертикулез ободочной кишки. Полипозное поражение ободочной кишки облигатный предрак которое может быть в виде: Одиночных полипов аденоматозный ворсичатый которые малигнизируются в 45 случаев особенно полипы величиной более 2 см; ворсинчатые полипы озлокачествляются чаще. Множественного полипоза ободочной кишки который.
35446. ПСИХИАТР, ПСИХОТЕРАПЕВТ, ПСИХОЛОГ – WHO ЕСТЬ КТО 35.5 KB
  В тот день я подумал идя домой что одна из главных проблем всех заинтересованных в этом споре сторон – определиться в терминах к примеру понятие параноидный для психиатра – это не совсем то что вкладывает в него психолог и нет числа этим трудностям перевода. При этом все – и психиатры и психологи – занимаются психотерапией на вполне законных основаниях и порой небезуспешно Еще одна проблема – илиили: двух мнений быть не может существует только единственно правильное учение и психотерапевт который его исповедует а все...
35447. СТРОЕНИЕ, РАЗВИТИЕ И ФУНКЦИОНАЛЬНОЕ ЗНАЧЕНИЕ РАЗЛИЧНЫХ ОТДЕЛОВ НЕРВНОЙ СИСТЕМЫ 15.49 KB
  В центре спинного мозга расположено серое вещество скопление нервных клеток нейронов окруженное белым веществом образованным нервными волокнами. Рефлексы мочеиспускания и дефекации рефлекторного набухания полового члена л иззержснчс семени у мужчины эрекция и ЭЯКУЛЯЦИЯ также связаны с функцией спинного мозга.Спинной мозг осуществляет и проводниковую функцию нервные волокна составляющие основную массу белого вещества образуют проводящее SjTH сииндаго мозга.Деятельность спинного мозга у человека в значительной подчинена координирующим...
35448. My Favourite Film Romeo and Juliet 14.76 KB
  And Ill try to tell you about this film. In the town of Verona there were two rich families, the Capulets and the Montagues. There was an old quarrel between those two families. One day Capulet made a great supper. At that supper Romeo saw Juliet and fell in love with her at ones.
35449. Gone with the wind. My Favourite Film 17.43 KB
  I don't like horror films nd I find them quite disgusting. Sometimes I my wtch police drm or historicl film but I'm not very keen on these types of films. Now let me tell you bout one of my fvourite films Gone with the wind by the novel by Mrgret Mitchell.
35450. Высшая нервная деятельность детей на протяжении первых 3 лет жизни 13.23 KB
  Высшая нервная деятельность детей раннего возраста характеризуется неуравновешенностью двух основных нервных процессов: процессы возбуждения преобладают над процессами торможения. В поведении детей много широко разлитых иррадиированных реакций. Поэтому нельзя требовать от детей быстрого прекращения начатого ими действия или выполнения какоголибо движения и быстрого переключения с одного действия на другое.