Читаем Linux API. Исчерпывающее руководство полностью

Определение функций инициализации и финализации внутри разделяемой библиотеки позволяет автоматически выполнять код при ее загрузке и выгрузке.

Переменная среды LD_PRELOAD дает возможность загружать разделяемые библиотеки заранее. Используя этот механизм, можно выборочно переопределить функции и другие символы, которые в противном случае были бы найдены в других библиотеках.

Для мониторинга работы динамического компоновщика можно присваивать различные значения переменной среды LD_DEBUG.

Дополнительная информация

Ознакомьтесь с источниками, приведенными в разделе 41.14.

42.8. Упражнения

42.1. Напишите программу, которая демонстрирует, что библиотека, закрытая с помощью функции dlclose(), не выгружается из памяти, если ее символы используются другой библиотекой.

42.2. Добавьте в программу из листинга 42.1 (dynload.c) вызов dladdr() для получения сведений об адресе, возвращенном функцией dlsym(). Выведите значения полей полученной структуры Dl_info и проверьте, соответствуют ли они вашим ожиданиям.

<p>43. Краткий обзор межпроцессного взаимодействия</p>

В этой главе представлен краткий обзор механизмов, с помощью которых процессы и потоки выполнения могут общаться друг с другом и синхронизировать свои действия. В следующих главах эта тема будет рассмотрена более подробно.

43.1. Классификация IPC-механизмов

На рис. 43.1 показано богатое разнообразие механизмов взаимодействия и синхронизации в UNIX. Все они делятся на три категории.

• Взаимодействие. Эти механизмы отвечают за обмен данными между процессами.

Синхронизация. Эти механизмы отвечают за синхронизацию работы процессов или потоков.

• Сигналы. Изначально они были предназначены для других целей, однако в некоторых ситуациях их можно использовать в качестве средства синхронизации. В редких случаях с их помощью можно организовать взаимодействие: номер сигнала как таковой является своеобразным видом информации, а сигналы реального времени могут нести в себе дополнительные данные (целое число или указатель). Подробное описание сигналов см. в главах 20–22.

Некоторые из этих механизмов занимаются синхронизацией, но в целом ко всем им применим термин «межпроцессное взаимодействие» (IPC).

Как показано на рис. 43.1, разные механизмы часто предоставляют похожие возможности, связанные с IPC. Тому есть несколько причин:

• похожие механизмы эволюционировали параллельно в разных вариантах UNIX и позже были перенесены на другие системы. Например, очереди FIFO были разработаны для System V, а (потоковые) сокеты впервые появились в BSD;

• некоторые новые механизмы были разработаны для устранения недостатков более ранних аналогов. Например, механизмы POSIX IPC (очереди сообщений, семафоры и разделяемая память) появились в качестве улучшенной версии более старых средств работы с IPC из System V.

Ряд механизмов, объединенных на рис. 43.1, на самом деле обладают довольно разными возможностями. Например, потоковые сокеты могут использоваться для взаимодействия по сети, тогда как очереди FIFO позволяют обмениваться данными только между процессами на одном компьютере.

43.2. Средства взаимодействия

Различные механизмы взаимодействия, представленные на рис. 43.1, позволяют процессам обмениваться данными друг с другом (эти же механизмы могут быть использованы для обмена информацией между потоками одного и того же процесса, но такая необходимость возникает не часто — потоки могут взаимодействовать с помощью общих глобальных переменных).

Рис. 43.1. Классификация IPC-механизмов в UNIX

Средства взаимодействия можно разделить на две категории.

• Средства передачи данных. Ключевой отличительной особенностью этих механизмов является понятие чтения и записи. Для общения друг с другом один процесс записывает данные в IPC-механизм, а другой считывает их оттуда. Такой подход подразумевает двухэтапную передачу данных между пользовательской и системной памятью: во время записи информация переходит из пространства пользователя в пространство ядра, а во время чтения — в обратном направлении (на рис. 43.2 данный случай проиллюстрирован на примере канала).

Разделяемая память. Позволяет процессам обмениваться информацией путем размещения ее в участках памяти, которые являются общими для обоих процессов (в ядре это достигается за счет привязки записей в таблице страниц памяти каждого из процессов к одним и тем же страницам физической памяти — см. рис. 45.2). Чтобы данные были доступны другому процессу, их можно поместить в сегмент разделяемой памяти. Поскольку данное действие не требует выполнения системных вызовов или передачи информации между пользовательской и системной памятью, этот механизм способен обеспечить очень быстрое взаимодействие.

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных