Как использовать boost :: async_system? - PullRequest
0 голосов
/ 28 января 2019

Я новичок в повышении, а также в многопоточности и запуске приложений с использованием библиотек.Для моей желаемой функциональности коллега рекомендовал мне использовать библиотеку boost :: process.

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

Однако есть одна, которую я не могу понять, как правильно использовать.Я даже не могу скомпилировать, не говоря уже о том, чтобы запустить его.И функция является boost :: process :: async_system.Я нигде не мог найти в интернете пошаговое руководство о том, как использовать эту функцию и что означают и делают отдельные компоненты.

Может ли кто-нибудь подробно объяснить мне отдельные аргументы и аргументы шаблона функции?Или предоставить ссылку на подробное руководство?

Ответы [ 2 ]

0 голосов
/ 03 июля 2019

Я просто использую Boost.Process, но пример кода, с которым я работаю, может быть полезен.

boost :: process: async_system () принимает 3 параметра: a boost :: asio :: io_context объект, функция обработчика выхода и команда, которую вы хотите запустить (точно так же как system (), и это может быть либо одна строка, либоболее одного аргумента).

После его вызова вы используете объект io_context из вызывающего потока для управления и мониторинга асинхронной задачи - я использую метод run_one (), который будет "Выполнять цикл обработки событий объекта io_contextвыполнить не более одного обработчика ", но вы также можете использовать другие методы для выполнения в течение некоторого времени и т. д.

Вот мой рабочий код:

#include <boost/process.hpp>
#include <iostream>

using namespace boost;

namespace {
    // declare exit handler function
    void _exitHandler(boost::system::error_code err, int rc) {
        std::cout << "DEBUG async exit error code: " 
                  << err << " rc: " << rc <<std::endl;
    }
}

int main() {
    // create the io_context
    asio::io_context ioctx;

    // call async_system
    process::async_system(ioctx, _exitHandler, "ls /usr/local/bin");

    std::cout << "just called 'ls /usr/local/bin', async" << std::endl;
    int breakout = 0; // safety for weirdness
    do {
        std::cout << " - checking to see if it stopped..." << std::endl;
        if (ioctx.stopped()) {
            std::cout << " * it stopped!" << std::endl;
            break;
        } else {
            std::cout << " + calling io_context.run_one()..." << std::endl;
            ioctx.run_one();
        }
        ++breakout;
    } while (breakout < 1000);

    return 0;
}

Единственное, чего не хватает в моем примере, это какиспользуйте boost :: asio :: async_result для захвата результата - примеры, которые я видел (в том числе здесь, на slashdot), все еще не имеют большого смысла для меня, но, надеюсь, это очень полезно.

Вотвывод вышеперечисленного на мой ссистема:

just called 'ls /usr/local/bin', async
 - checking to see if it stopped...
 + calling io_context.run_one()...
 - checking to see if it stopped...
 + calling io_context.run_one()...
VBoxAutostart       easy_install        pybot
VBoxBalloonCtrl     easy_install-2.7    pyi-archive_viewer
   ((omitted - a bunch more files from the ls -l command))
DEBUG async exit error code: system:0 rc: 0
 - checking to see if it stopped...
 * it stopped!
Program ended with exit code: 0
0 голосов
/ 28 января 2019

Мне нравятся примеры здесь: https://theboostcpplibraries.com/boost.thread-futures-and-promises

Например, посмотрите на пример 44.16, они ясно показывают, как использовать асинхронное:

#define BOOST_THREAD_PROVIDES_FUTURE
#include <boost/thread.hpp>
#include <boost/thread/future.hpp>
#include <iostream>

int accumulate()
{
  int sum = 0;
  for (int i = 0; i < 5; ++i)
    sum += i;
  return sum;
}

int main()
{
  boost::future<int> f = boost::async(accumulate);
  std::cout << f.get() << '\n';
}

Ожидание происходит в getметод, не раньше.Вы также можете использовать механизм ожидания.

Что касается компиляции, вам нужно сначала собрать boost.Сборка подробно объясняется здесь: https://www.boost.org/doc/libs/1_62_0/more/getting_started/windows.html

Большинство частей библиотеки работают только с заголовками.Для asio необходимо создание бинарных библиотек (также объяснено в ссылке).В вашем проекте (т.е. проектах Visual Studio, проекте XCode или просто некоторых файлах make) вам необходимо установить заголовки include и библиотеки boost для его использования.Ссылка выше помогает и в этом.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...