Энтони Уильямс - Параллельное программирование на С++ в действии. Практика разработки многопоточных программ

Здесь есть возможность читать онлайн «Энтони Уильямс - Параллельное программирование на С++ в действии. Практика разработки многопоточных программ» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: Москва, Год выпуска: 2012, ISBN: 2012, Издательство: ДМК Пресс, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

Параллельное программирование на С++ в действии. Практика разработки многопоточных программ: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

В наши дни компьютеры с несколькими многоядерными процессорами стали нормой. Стандарт С++11 языка С++ предоставляет развитую поддержку многопоточности в приложениях. Поэтому, чтобы сохранять конкурентоспособность, вы должны овладеть принципами и приемами их разработки, а также новыми средствами языка, относящимися к параллелизму.
Книга «Параллельное программирование на С++ в действии» не предполагает предварительных знаний в этой области. Вдумчиво читая ее, вы научитесь писать надежные и элегантные многопоточные программы на С++11. Вы узнаете о том, что такое потоковая модель памяти, и о том, какие средства поддержки многопоточности, в том числе запуска и синхронизации потоков, имеются в стандартной библиотеке. Попутно вы познакомитесь с различными нетривиальными проблемами программирования в условиях параллелизма.

Параллельное программирование на С++ в действии. Практика разработки многопоточных программ — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Листинг С.4.Класс dispatcher

namespace messaging {

class close_queue {}; ← Сообщение о закрытии очереди

class dispatcher {

queue* q; │ Экземпляры

bool chained; │ диспетчера нельзя

копировать

dispatcher(dispatcher const&)=delete;←┘

dispatcher& operator=(dispatcher const&)=delete;

template<

typename Dispatcher,│ Разрешить экземплярам

typename Msg, │ TemplateDispatcher доступ

typename Func> ←┘ к закрытым частям класса

friend class TemplateDispatcher;

void wait_and_dispatch()

{ (1) В цикле ждем и диспетчеризуем

for (;;) {←┘ сообщения

auto msg = q->wait_and_pop();

dispatch(msg);

}

} (2) dispatch() смотрит, не пришло ли

сообщение close_queue, и, если

bool dispatch (←┘ да, возбуждает исключение

std::shared_ptr const& msg) {

if (dynamic_cast*>(msg.get())) {

throw close_queue();

}

return false;

}

public: │ Экземпляры диспетчера

dispatcher(dispatcher&& other):←┘ можно перемещать

q(other.q), chained(other.chained) {│ Объект-источник не должен

other.chained = true; ←┘ ждать сообщений

}

explicit dispatcher(queue* q_): q(q_), chained(false) {}

template

TemplateDispatcher

handle(Func&& f)←┐ Сообщения конкретного типа

{ (3) обрабатывает TemplateDispatcher

return TemplateDispatcher(

q, this, std::forward(f));

}

~dispatcher() noexcept(false)←┐ Деструктор может

{ (4) возбудить исключение

if (!chained) {

wait_and_dispatch();

}

}

};

}

Экземпляр dispatcher, возвращенный функцией wait(), немедленно уничтожается, так как является временным объектом, и, как уже было сказало, вся работа выполняется в его деструкторе. Деструктор вызывает функцию wait_and_dispatch(), которая в цикле (1)ожидает сообщения и передает его функции dispatch(). Сама функция dispatch() (2)проста, как правда: она проверяет, не получено ли сообщение типа close_queue, и, если так, то возбуждает исключение; в противном случае возвращает false, извещая, что сообщение не обработало. Именно из-за исключения close_queueдеструктор и помечен как noexcept(false) (4); без этой аннотации действовала бы подразумеваемая спецификация исключений для деструктора — noexcept(true), означающая, что исключения не допускаются, и тогда исключение close_queueпривело бы к завершению программы.

Но просто вызывать функцию wait()особого смысла не имеет — как правило, нам нужно обработать полученное сообщение. Для этого предназначена функция-член handle() (3). Это шаблон, и тип сообщения нельзя вывести, поэтому необходимо явно указать, сообщение какого типа обрабатывается, и передать функцию (или допускающий вызов объект) для его обработки. Сама функция handle()передает очередь, текущий объект dispatcherи функцию-обработчик новому экземпляру шаблонного класса TemplateDispatcher, который обрабатывает сообщения указанного типа. Код этого класса показан в листинге С.5. Именно поэтому мы проверяем флаг chainedв деструкторе перед тем, как приступить к ожиданию сообщения; он не только предотвращает ожидание объектами, содержимое которых перемещено, но и позволяет передать ответственность за ожидание новому экземпляру TemplateDispatcher.

Листинг С.5.Шаблон класса TemplateDispatcher

namespace messaging {

template<

typename PreviousDispatcher, typename Msg, typename Func>

class TemplateDispatcher {

queue* q;

PreviousDispatcher* prev;

Func f;

bool chained;

TemplateDispatcher(TemplateDispatcher const&) = delete;

TemplateDispatcher& operator=(

TemplateDispatcher const&) = delete;

template<

typename Dispatcher, typename OtherMsg, typename OtherFunc>

friend class TemplateDispatcher;←┐ Все конкретизации

void wait_and_dispatch() │ TemplateDispatcher

{ │ дружат между собой

for (;;) {

auto msg = q->wait_and_pop();

if (dispatch(msg))←┐ Если мы обработали

break; │ сообщение выходим

} (1) из цикла

}

bool dispatch(std::shared_ptr const& msg) {

if (wrapped_message* wrapper =

dynamic_cast*>(

msg.get())) { ←┐ Проверяем тип

f(wrapper->contents);│ сообщения и

return true; │ вызываем

} (2) функцию

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ»

Представляем Вашему вниманию похожие книги на «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ»

Обсуждение, отзывы о книге «Параллельное программирование на С++ в действии. Практика разработки многопоточных программ» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x