Класс so_4::disp::active_group::impl::dispatcher_t

Граф наследования:so_4::disp::active_group::impl::dispatcher_t:

so_4::rt::dispatcher_t

Полный список членов класса


Подробное описание

Диспетчер с активными группами.

Начиная с:
v.4.2.6 Все агенты, составляющие активную группу работают на контексте одной нити, выделенной этой группе.
Диспетчер обслуживает только агентов, которые входят в активные группы. Остальных агентов и нить таймера должен обслуживать дополнительный диспетчер, которые передается диспетчеру с активными группами в качестве параметра.

Подчиненый диспетчер должен быть динамически созданным объектом, который будет уничтожен в деструкторе диспетчера с активными группами.

Для того, чтобы сделать агент членом активной группы необходимо вызвать метод introduce_agent(). Если такой активной группы еще не существовала, то она создается и для нее стартуется отдельная рабочая нить.

Для того, чтобы изъять агент из активной группы необходимо вызвать метод remove_agent(). Если в активной группе больше не осталось ни одного агента, то активная группа уничтожается, а выделенная ей рабочая нить завершается.

Внимание:
данный класс спроектирован так, чтобы в программе был только один объект этого типа.

Открытые члены

 dispatcher_t (so_4::rt::dispatcher_t *subordinate_disp)
 Основной инициализирующий конструктор.
virtual ret_code_t start ()
 Запустить диспетчер.
virtual void shutdown ()
 Дать сигнал диспетчеру завершить работу.
virtual void wait ()
 Ожидать полного завершения работы диспетчера.
virtual void setup_dispatcher_binding (so_4::rt::agent_t &agent)
 Выполнение привязки агента к конкретному ресурсу диспетчера.
virtual void push_delayed_msg (const so_4::rt::msg_data_t &msg_data, unsigned int delay, unsigned int period=0)
 Поставить отложенное сообщение в очередь.
virtual void destroy_all_agent_msg (const std::string &agent_name)
 Изъять все ожидающие сообщения данного агента.

Открытые статические члены

static void introduce_agent (const std::string &group_name, const std::string &agent_name)
 Добавить еще одного агента в активную группу.
static void remove_agent (const std::string &group_name, const std::string &agent_name)
 Изъять агента из активной группы.

Закрытые статические члены

static ACE_Thread_Mutex & lock ()
 Замок для синхронизации доступа к внутренним частям диспетчера.

Закрытые данные

std::auto_ptr
< so_4::rt::dispatcher_t
m_subordinate_disp
 Подчиненный диспетчер.
group_map_t m_groups
 Карта существующих активных групп.
agent_map_t m_agents
 Карта агентов, являющихся членами активных групп.
bool m_is_started
 Признак того, что диспетчер запущен.

Закрытые статические данные

static dispatcher_tm_instance
 Указатель на единственный объект диспетчер. Ссылка на этот объект будет передаваться в рабочие нити для активных групп.

Конструктор(ы)

so_4::disp::active_group::impl::dispatcher_t::dispatcher_t ( so_4::rt::dispatcher_t subordinate_disp  ) 

Основной инициализирующий конструктор.

Аргументы:
subordinate_disp  Подчиненный диспетчер.

Перекрестные ссылки lock() и m_instance.


Методы

ret_code_t so_4::disp::active_group::impl::dispatcher_t::start (  )  [virtual]

Запустить диспетчер.

Сначала запускается подчиненный диспетчер. Затем, если все прошло нормально, наш диспетчер.

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки lock(), m_is_started и m_subordinate_disp.

void so_4::disp::active_group::impl::dispatcher_t::shutdown (  )  [virtual]

Дать сигнал диспетчеру завершить работу.

Сначала дается сигнал на останов для всех активных групп, затем для подчиненного диспетчера.

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки lock(), m_groups, m_is_started и m_subordinate_disp.

void so_4::disp::active_group::impl::dispatcher_t::wait (  )  [virtual]

Ожидать полного завершения работы диспетчера.

Сначала ожидается завершение всех активных групп, затем ожидается останов подчиненного диспетчера.

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки so_4::disp::active_group::impl::destroy_active_group_thread_map(), lock(), m_agents, m_groups, m_is_started и m_subordinate_disp.

void so_4::disp::active_group::impl::dispatcher_t::setup_dispatcher_binding ( so_4::rt::agent_t agent  )  [virtual]

Выполнение привязки агента к конкретному ресурсу диспетчера.

Начиная с:
v.4.4.0-b6

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки lock(), m_agents, m_groups, m_subordinate_disp, so_4::rt::agent_t::so_query_name() и so_4::rt::agent_t::so_set_dispatcher_binding().

void so_4::disp::active_group::impl::dispatcher_t::push_delayed_msg ( const so_4::rt::msg_data_t msg_data,
unsigned int  delay,
unsigned int  period = 0 
) [virtual]

Поставить отложенное сообщение в очередь.

Задействуется подчиненный диспетчер.

Аргументы:
delay  Для переодического сообщения указывает время, через которое сообщение должно возникнуть в первый раз
period  Отличен от 0 для переодических сообщений

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки m_subordinate_disp.

void so_4::disp::active_group::impl::dispatcher_t::destroy_all_agent_msg ( const std::string &  agent_name  )  [virtual]

Изъять все ожидающие сообщения данного агента.

Задействуется подчиненный диспетчер.

Замещает so_4::rt::dispatcher_t.

Перекрестные ссылки m_subordinate_disp.

void so_4::disp::active_group::impl::dispatcher_t::introduce_agent ( const std::string &  group_name,
const std::string &  agent_name 
) [static]

Добавить еще одного агента в активную группу.

Аргументы:
group_name  Имя активной группы.
agent_name  Имя агента.

Перекрестные ссылки lock(), m_agents, m_groups, m_instance, m_is_started, so_4::disp::active_group::impl::thread_info_t::m_thread и so_4::disp::reuse::work_thread::work_thread_t::start().

Используется в so_4::disp::active_group::impl::traits_t::init().

void so_4::disp::active_group::impl::dispatcher_t::remove_agent ( const std::string &  group_name,
const std::string &  agent_name 
) [static]

Изъять агента из активной группы.

Аргументы:
group_name  Имя активной группы.
agent_name  Имя агента.

Перекрестные ссылки lock(), m_agents, m_groups, m_instance, m_is_started, so_4::disp::reuse::work_thread::work_thread_t::shutdown() и so_4::disp::reuse::work_thread::work_thread_t::wait().

Используется в so_4::disp::active_group::impl::traits_t::deinit().


Данные класса

Признак того, что диспетчер запущен.

Начиная с:
v.4.4.0-b6
Пока этот признак равен true можно модифицировать содержимое m_groups и m_agents.

Используется в introduce_agent(), remove_agent(), shutdown(), start() и wait().


Документация по SObjectizer v.4.4 'Тебуломста'. Последние изменения: Thu Sep 18 10:26:48 2008. Создано системой  doxygen1.5.6 Intervale SourceForge.net Logo