Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> coroutines в С++ 
:(
    Опции темы
GoldFinch
Дата 25.3.2010, 12:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



****


Профиль
Группа: Завсегдатай
Сообщений: 2141
Регистрация: 30.11.2008

Репутация: 15
Всего: 26



Кто нибудь применял сопрограммы на практике?

Я пока нашел только такие варианты реализации:
  • использование API ОС (например Fiber'ы в винде)  - Boost.Coroutine (в разработке уже несколько лет, в буст не входит)
  • различные варианты с устройством Даффа, в зависимости от сложности макросов препроцессора может выглядеть весьма прилично, например yield может выглядеть так:
    Код

    yield asio::async_write(socket, asio::buffer(working_buffer, length), *this);  // yield - макрос
    // сопрограмма реализована как функтор, который постоянно передается asio в async_* функции

    (http://blog.think-async.com/2009/08/composed-operations-coroutines-and-code.html)
  • ручная реализация переключения контекстов, с выделением стека в хипе
С фиберами все выглядит просто и удобно, но у меня есть сомнения что фибер расходует меньше памяти чем нормальный поток.
Устройство Даффа плохо тем что возникают потенциальные сложности с локальными объектами в сопрограмме, макросы тяжело отлаживать.
Ручная работа со стеком крайне сложна в реализации и фактически является заменой фиберов.


Это сообщение отредактировал(а) GoldFinch - 25.3.2010, 12:26
PM MAIL ICQ   Вверх
SABROG
Дата 28.3.2010, 13:51 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Hacker
****


Профиль
Группа: Завсегдатай
Сообщений: 2481
Регистрация: 18.9.2006

Репутация: 4
Всего: 91



Я правильно понимаю, сопрограмма это таже же асинхронная очередь событий как и в Qt? То есть один поток используется для обработки нескольких циклов. Предположим я вызываю сопрограмму, её вызов становится в очередь до того момента когда я выйду из итерационного цикла и не войду в него снова. Как только я покинул область видимости функции вызывается моя сопрограмма, которая блокирует вход моего предыдущего цикла пока не завершится и не вызовет меня обратно точно также по завершении. В общем yield это аналог emit в Qt с Qt::QueuedConnection.


--------------------
Национальная группа Russian Federation на QtCentre.
PM MAIL   Вверх
xvr
Дата 29.3.2010, 14:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 60
Всего: 223



Цитата(SABROG @  28.3.2010,  13:51 Найти цитируемый пост)
Предположим я вызываю сопрограмму, её вызов становится в очередь до того момента когда я выйду из итерационного цикла и не войду в него снова
Классический вызов сопрограммы вызывает НЕМЕДЛЕННОЕ переключение на вызванную сопрограмму. Обратное переключение так же должно производится явно таким же вызовом (но теперь в другую сторону)


PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0667 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.