Logo    
Деловая газета CitCity.ru CITKIT.ru - все об Open Source Форумы Все публикации Учебный центр Курилка
CitForum    CITForum на CD    Подписка на новости портала Море(!) аналитической информации! :: CITFORUM.RU
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

27.01.2017

Google
WWW CITForum.ru
С Новым годом!
2006 г.

Параллельное дежавю или... "эффект Бартини"

Вячеслав Любченко

 

Достоверно зная то, что было, мы над прошлым уже не властны. О будущем у нас есть всего лишь предположения, но только в будущем мы можем что-то предотвратить, а что-то вызвать к жизни. Можно сделать так, чтобы жизнь стала лучше.

Роберто Бартини. (Каминский Ю. Одиссея "Красного барона")

Дежавю...
Прочитав обзор майского номера журнала Computer (IEEE Computer Society, Vol. 39, No. 5, May 2006) С.Кузнецова "Возвращение микроядерных операционных систем" (см. [1]), я словно вернулся в прошлое. Вспомнились и итоговые строки его же статьи того времени: "Жаль, что среди нас не нашелся гений..."(см. статью "Блеск и нищета легковесных процессов"[2]).

Предыстория...
Почти десять лет минуло с момента моей первой и единственной встречи с Сергеем Кузнецовым и знакомства с его статьями того времени: первая упомянута выше, вторая - "Менталитет программиста, или ностальгия по программированию"[3]. В результате я написал свою - "Блеск и нищета отечественного программирования"[4]. И теперь стало видно, что прошедшее время это то расстояние, с которого можно, может, по-новому взглянуть на вопросы, которые были затронуты в той беседе, и/или уточнить наше отношение к ним.

"Параллельное дежавю"...
Как это ни прискорбно, но время не добавило ясности в решение проблем, которые были актуальны уже в те времена. И неужели тоска по гению, который бы разрешил наши "параллельные вопросы", должна нас беспокоить так же, как и десять лет назад?

Времена застоя...
Параллельное программирование имеет давнюю историю (см. замечание о легковесных процессах в [2]). Но, оглядываясь на прошедшее десятилетие, сравнивая с тем, что было и что есть, можно сказать, что это были, к большому сожалению, "застойные времена" параллельного программирования.

Что нас ждет...
Обнадеживает то, что перемены все же грядут. Налицо даже своеобразная предреволюционная ситуация, спровоцированная появлением многоядерных процессоров. Последнее привело к активному обсуждению проблем параллельного программирования, что, без всяких сомнений, служит стимулом к поиску разрешения его проблем. И, может, возврат к микроядерным системам, как в свое время реанимация легковесных процессов (см. [2]), одно из следствий такой ситуации?

Чем сердце успокоится ...
В будущем вне каких-либо желаний и/или пристрастий параллельное программирование из категории кастового перейдет в категорию обыденного. Оно станет доминирующим, как сейчас таким является последовательное. Потому нынешние жалобы на его трудность и сложность (подробнее см. [1]), особенно в свете прошедших лет, выглядят как нытье: параллельным программированием заняться придется, как бы это ни было тяжело, а для кого-то, может быть, даже противно!

В поисках гения...
Конечно, "жаль, что... не нашелся гений" тогда, но нашли ли мы его за прошедшее время? А, может, и не надо кого-то искать? Может нужно просто "под другим углом" взглянуть на текущую ситуацию и на ту, которая была? На ситуацию, которая существовала и, как можно сделать вывод из обзора, пока еще существует в параллельном программировании. Может, есть что-то, что мы не заметили и/или не замечаем?

Что делать? ...
Не заостряясь на проблеме "кто виноват?", хочется остановиться на проблеме "что делать?". Это, как минимум, приятнее, поскольку случаи самобичевания "виноватых" лично мне не известны.

Частично ответ на заданный вопрос уже дан мною в упомянутой выше статье. В [5] было даже предложено, как распознать и отсеивать "плохие", т.е. в первую очередь не детерминированные системы (именно "не детерминированные"", а не "недерминированные"). За прошедший десятилетний период я написал множество статей на тему параллельного программирования (в основном - автоматного) и решил достаточное число параллельных задач, проясняющих те или иные стороны параллельных процессов. Это и многое другое представлено на сайте SoftCraft в разделе КА-технология: И это уже мое представление о том, что делать, которое, к слову сказать, не меняется уже лет двадцать (!).

О менталитете...
Хочется сказать несколько слов и о менталитете программистов. Он есть - спору нет! И даже я сказал бы, что "наш" во многом уже совпадает с "их". Т.е. мы все больше и больше теряем самостоятельность действий и самостоятельность мышления (можно даже утверждать, что по большому счету фактически все это уже утрачено)... Но дело по большому счету не в этом, а в том, что - было бы "можно сделать" (см. эпиграф), но сделано не было. И, как я могу полагать, отчасти в силу именно этого пресловутого "менталитета".

Порочность многопоточности...
То, что породил менталитет программистов, от чего они никак не хотят (или не могут?) отказаться, легко показать на простейшем примере. Он рассмотрен в статье, где приведены результаты тестирования простейшего многопоточного приложения. Вот в порочности такого "многопоточного подхода" мне и не удалось пока убедить ни "наших" ни "их" программистов. Казалось бы, есть все и на все вкусы - модель, теория, решенные задачи, технология, в конце концов... Но, похоже, существование более сложного теста и математически строгого теста (см. подробнее [5]) еще более не убеждает программистов с их нынешним (бывшим?) "менталитетом". И это для меня основной и не очень утешительный итог прошедшего десятилетия.

Может, я был не столь убедителен, может, не те аргументы приводил и привожу? Удивляет одно, что решение таких задач, если говорить конкретно, как задачи Дейкстры о философах и о разделении множеств, формулировка и решение задачи о моделировании RS-триггера и т.д. и т.п., как показала жизнь, для программистов не аргументы. Повторюсь, - и это не аргументы?!

Здесь я привел совсем простой пример. Проще просто уже быть не может. Те же, кого по-прежнему привлекают более сложные задачи, могут просмотреть (может, кто-то даже пересмотреть) уже напечатанные мои статьи в журналах Мир ПК и Открытые системы, а также материалы сайта SoftCraft.

О настоящем и будущем...
Но дело, думаю, все же не в менталитете, хотя и в нем тоже, а в сложившейся ситуации. В том числе в той, которая была, и, несомненно, в той, которая будет. Сейчас в программировании она меняется весьма резко (я бы не сказал, что резво) с последовательной на параллельную. И, надеюсь, что уже никакой "менталитет" не повлияет на необходимость трезво оценивать новые подходы в программировании. Я сознательно не подчеркиваю - в параллельном, т.к. последовательное скоро отомрет, как система DOS (если быть точным, то станет частью параллельного).

Только ... все, что еще предстоит сделать, можно было бы сделать в течение прошедших десяти лет. Тогда и сейчас было бы ... "лучше". А так имеем "параллельную ситуацию" - не детерминированную и тяжеловесную в работе. Вопрос еще и в том насколько долго она будет оставаться таковой...

Не хотелось бы сложившийся "параллельный тупик" объяснять каким-то "профессиональным менталитетом" или даже - "интересом", но и исключать все это нельзя. Остается только надеяться, что на свой менталитет и, особенно, интерес мы в силах повлиять сами. Или помимо нашего желания и, может, нашего участия, за нас это сделает... "ситуация"? Опять же - когда?

"Можно сделать так, чтобы жизнь стала лучше", но все чаще возникает чувство, что кого-то очень уж устраивает то, что уже есть...

Список литературы
  1. Кузнецов С. Возвращение микроядерных операционных систем. Открытые системы #05/06
  2. Кузнецов С. Блеск и нищета легковесных процессов. Computerworld №31/96
  3. Кузнецов С. Менталитет программиста, или ностальгия по программированию. Computerworld №31/96
  4. Любченко В. Блеск и нищета отечественного программирования. "СофтМаркет" № №10/97, стр. 6.
  5. Любченко В. Фантазия или программирование? "Мир ПК", №10/97, с.116-119.

Подписка на новости IT-портала CITForum.ru
(библиотека, CITKIT.ru, CitCity)

Новые публикации:

24 декабря

CITKIT.ru:

  • Новогодние поздравления
  • Сергей Кузнецов. Цикл Операционные системы: Ностальгия по будущему:

  • Алексей Федорчук. OpenSolaris 2008.11 Release

  • Сергей Голубев:

  • Евгений Чайкин aka StraNNik (Блогометки):

    17 декабря

  • С.Д.Кузнецов. Базы данных. Вводный курс

    10 декабря

    CITKIT.ru:

  • OpenSolaris 2008.11 Release

  • Альтернативные ОС: две грустные истории (С.Кузнецов)
  • Nokia N810 — доведение до ума
  • CitCity:

  • Платформа 2009: заоблачные перспективы Microsoft

    4 декабря

  • Лекция С.Д.Кузнецова Понятие модели данных. Обзор разновидностей моделей данных

    CITKIT.ru:

  • OpenSolaris 2008.11 Release. Первые впечатления

  • Linux vs FreeBSD: продолжим "Священные войны"?

  • Nokia N810 as is

  • Индульгенция для FOSS

  • Друзья СПО'2008

    26 ноября

  • Нечеткое сравнение коллекций: семантический и алгоритмический аспекты

    CitCity:

    CITKIT.ru:

  • Глава из книги А.Федорчука
    Сага о FreeBSD:
  • 19 ноября

  • Проблемы экономики производства крупных программных продуктов

  • Язык модификации данных формата XML функциональными методами

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    Заметки к книге:

  • FreeBSD: монтирование сменных устройств и механизм HAL
  • Текстовый редактор ee

    12 ноября

  • Правило пяти минут двадцать лет спустя, и как флэш-память изменяет правила (Гоц Грейф, перевод: Сергей Кузнецов)

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:
  • OSS в России: взгляд правоведа (В.Житомирский)

  • Новая статья из цикла С.Голубева "Железный марш":

    29 октября

  • О некоторых задачах обратной инженерии

  • Веб-сервисы и Ruby

  • Тестирование web-приложений с помощью Ruby

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

  • PuppyRus Linux - беседа с разработчиком (С.Голубев)

  • Сергей Кузнецов. Заметка не про Linux

    22 октября

  • Обзор методов описания встраиваемой аппаратуры и построения инструментария кросс-разработки

    CITKIT.ru:

  • Сергей Кузнецов. Почему я равнодушен к Linux

  • Глава из книги А.Федорчука
    Сага о FreeBSD:
  • Что надо иметь
    3. Базовые познания

    CitCity:

  • Управление IT-инфраструктурой на основе продуктов Microsoft

    15 октября

  • Методы бикластеризации для анализа интернет-данных

    CitCity:

  • Разъемы на ноутбуках: что они дают и зачем их так много?
  • AMD Puma и Intel Centrino 2: кто лучше?

    CITKIT.ru:

  • Новый цикл статей С.Голубева
    Железный марш:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    8 октября

  • Автоматизация тестирования web-приложений, основанных на скриптовых языках
  • Опыт применения технологии Azov для тестирования библиотеки Qt3

    Обзоры журнала Computer:

  • SOA с гарантией качества
  • Пикоджоуль ватт бережет
  • ICT и всемирное развитие

    CitCity:

  • Пиррова победа корпорации Microsoft

    CITKIT.ru:

  • Главы из книги А.Федорчука
    Сага о FreeBSD:

    Статья из архива:

  • Я живу в FreeBSD (Вадим Колонцов)

    Новые Блогометки:

  • Перекройка шаблона Blogger или N шагов к настоящему
  • Blogger. Comment style
  • Screenie или глянцевый снимок экрана

    2 октября

    CITKIT.ru:

  • Сага о FreeBSD (А. Федорчук)

    Zenwalk: пакет недели

  • Банинг — интеллектуальное развлечение (С.Голубев)

    CitCity:

    25 сентября

  • Клермонтский отчет об исследованиях в области баз данных

    CITKIT.ru:

  • Пользователям просьба не беспокоиться... (В.Попов)

  • Снова про ZFS: диск хорошо, а два лучше
  • Командная оболочка tcsh (А.Федорчук)

    Zenwalk: пакет недели

    17 сентября

  • T2C: технология автоматизированной разработки тестов базовой функциональности программных интерфейсов
  • Технология Azov автоматизации массового создания тестов работоспособности

    CITKIT.ru:

  • FreeBSD: ZFS vs UFS, и обе-две — против всех (А.Федорчук)

    Zenwalk: пакет недели

  • Дачнет — практика без теории (С.Голубев)

    10 сентября

  • За чем следить и чем управлять при работе приложений с Oracle
  • Планировщик заданий в Oracle
    (В.Пржиялковский)

    CITKIT.ru:

  • Microsoft: ответный "боян" (С.Голубев)

  • Причуды симбиоза, или снова "сделай сам" (В.Попов)

  • Файловые системы современного Linux'а: последнее тестирование
  • Zsh. Введение и обзор возможностей
    (А.Федорчук)

    Описания пакетов Zenwalk: Zsh, Thunar, Thunar-bulk-rename, Xfce4-places-plugin, Xfce4-fsguard-plugin

    Блогометки:

  • Google Chrome
  • Лончер для ASUS Eee PC 701

    3 сентября

    CITKIT.ru:

  • Заметки о ядре (А.Федорчук):

    Добавлены описания пакетов Zenwalk: Galculator, Screenshot, Gnumeric, Pidgin

    В дискуссинном клубе:

  • И еще о Википедии и Google Knol

  • Лекция для начинающего линуксоида (С.Голубев)

    26 августа

  • Транзакционная память (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • Открыт новый проект Zenwalk: пакет недели

  • Статья Текстовые процессоры и их быстродействие: конец еще одной легенды?

    21 августа

    CITKIT.ru:

  • Почему школам следует использовать только свободные программы (Ричард Столлман)
  • Беседа Сергея Голубева с учителем В.В.Михайловым

  • Википедия или Гуглезнание? Приглашение к обсуждению (Алексей Федорчук)
  • Народная энциклопедия от Google (StraNNik)

  • Обзор Mandriva 2009.0 Beta 1 Thornicrofti
  • Новичок в Линукс: Оптимизируем Mandriva 2008.1

  • Книга Zenwalk. Приобщение к Linux:

    13 августа

    CitCity:

  • Мирный Atom на службе человеку. Обзор платы Intel D945GCLF с интегрированным процессором
  • Обзор процессоров Intel Atom 230 на ядре Diamondville

  • iPhone - год спустя. Скоро и в России?

    CITKIT.ru:

  • Интермедия 3.4. GRUB: установка и настройка (из книги Zenwalk. Приобщение к Linux)

    6 августа

  • СУБД с хранением данных по столбцами и по строкам: насколько они отличаются в действительности? (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • Интермедия 2.2. Что неплохо знать для начала (из книги Zenwalk. Приобщение к Linux)

  • И снова про шрифты в Иксах (А.Федорчук)

  • 20 самых быстрых и простых оконных менеджеров для Linux

  • Дело о трех миллиардах (С.Голубев)

    30 июля

  • OLTP в Зазеркалье (Пересказ: С. Кузнецов)

    CitCity:

  • Будущее BI в облаках?
  • Тиражные приложения и заказная разработка. Преимущества для заказчика
  • Дискуссия со сторонниками заказной разработки

    CITKIT.ru:

  • Новые главы книги Zenwalk. Приобщение к Linux:
  • Глава 8. Пакеты: средства установки, системы управления, системы построения
  • Глава 9. Zenwalk: репозитории, пакеты, методы установки

    23 июля

    CITKIT.ru:

  • Все против всех. 64 vs 32, Intel vs AMD, tmpfs vs ext3
  • Две головы от Intel

  • Zenwalk: обзор штатных приложений (глава из книги "Zenwalk. Приобщение к Linux")

  • Нормально, Григорий...

    16 июля

    Обзоры журнала Computer:

  • Перспективы и проблемы программной инженерии в XXI веке
  • Большие хлопоты с большими объемами данных
  • Перспективы наноэлектроники

    CITKIT.ru:

  • Интермедия о лицензиях (А.Федорчук. "Zenwalk. Приобщение к Linux")

  • Есть ли будущее у KDE?

  • Linux в школе: альтернативный вариант в задачах

  • Шифр (приключения агента Никодима)

    10 июля

    CITKIT.ru:

  • Новые разделы книги А. Федорчука Zenwalk. Приобщение к Linux:
  • Интермедия вступительная. Linux или GNU/Linux? Как вас теперь называть?
  • Глава 5. Среда Xfce
  • Глава 6. Xfce: приложения и плагины

  • ZUR (Zenwalk User Repository) FAQ

    2 июля

  • Персистентность данных в объектно-ориентированных приложениях (С. Кузнецов)

    CITKIT.ru:

  • Новые разделы книги А. Федорчука Zenwalk. Приобщение к Linux:
  • Интермедия 1.2. Дорога к Zenwalk'у. Период бури и натиска
  • Интермедия 3.3. Немного о Linux'е и "железе"
  • Глава 4. Настройка: инструментами и руками
  • Интермедия 4.1. Zenpanel и конфиги: поиски корреляции

  • Интервью с Жан-Филиппом Гийоменом, создателем дистрибутива Zenwalk

  • Linux в школе: первые итоги (С. Голубев)

    25 июня

    CITKIT.ru:

  • Zenwalk. Приобщение к Linux (А. Федорчук)

  • Логика и риторика (С.Голубев)

  • Технология Tru64 AdvFS

  • Ханс Райзер предлагает отвести полицейских к телу Нины

    18 июня

  • Проекты по управлению данными в Google (Пересказ: С. Кузнецов)

    CITKIT.ru:

  • ОС и поддержка "железа": мифы и реальность (А. Федорчук)

  • Linux в школе: другие дистрибутивы

  • Пинок (С. Голубев)

    4 июня

  • Ландшафт области управления данными: аналитический обзор (С. Кузнецов)

    CITKIT.ru:

  • Linux в школе: слово заинтересованным лицам

  • SlackBuild: пакеты своими руками

  • Linux от компании Novell. Установка и обзор openSUSE Linux

    Все публикации >>>




  • IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

    Информация для рекламодателей Пресс-релизы — pr@citcity.ru
    Послать комментарий
    Информация для авторов
    Rambler's Top100 This Web server launched on February 24, 1997
    Copyright © 1997-2017 CIT, © 2001-2017 CIT Forum
    Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...