boost::asio::steady_timer 在 boost::d ll 中不起作用

boost::asio::steady_timer doesn't work in boost::dll

本文关键字:boost ll 不起作用 timer asio steady      更新时间:2023-10-16

boost :: asio :: stestend_timer在可执行文件中启动时工作正常。通过在DLL中启动Steady_timer,计时器立即到期。我的代码有什么问题?它是boost :: asio?

中的错误

api.h:

#include <boost/asio.hpp>
class my_api {
public:
   virtual void startTimer(boost::asio::io_service& ioservice) = 0;
   virtual ~my_api() {};
};

dll.cpp:

#include <iostream>
#include <boost/dll.hpp>
#include "api.h"
class my_plugin : public my_api {
public:
   void startTimer(boost::asio::io_service& ioservice) {
      std::cout << "start timer (15 sec)n";
      boost::asio::steady_timer timer{ ioservice, std::chrono::seconds{ 15 } };
      timer.async_wait([](const boost::system::error_code &ec) { std::cout << "15 secn"; });
   };
    ~my_plugin() {};
};
static boost::shared_ptr<my_api> createPlugin() {
   return boost::shared_ptr<my_api>(new my_plugin());
}
BOOST_DLL_ALIAS(
   createPlugin,
   create_plugin
)

main.cpp:

#include <boost/dll/import.hpp>
#include <boost/function.hpp>
#include <boost/asio.hpp>
#include <iostream>
#include "../DLL/api.h"
int main() {
   boost::asio::io_service ioservice;
   /* load dll */
   boost::filesystem::path shared_library_path("..\Debug");
   shared_library_path /= "DLL";
   boost::function<boost::shared_ptr<my_api>()> creator = boost::dll::import_alias<boost::shared_ptr<my_api>()>(
      shared_library_path,
      "create_plugin",
      boost::dll::load_mode::append_decorations
   );
   boost::shared_ptr<my_api> plugin = creator();
   /* set timer 10 sec */
   std::cout << "start timer (10 sec)n";
   boost::asio::steady_timer timer{ ioservice, std::chrono::seconds{ 10 } };
   timer.async_wait([](const boost::system::error_code &ec) { std::cout << "10 secn"; });
   /* create my_plugin in dll with timer 15 sec */
   plugin->startTimer(ioservice);
   ioservice.run();
   return 0;
}

输出:

start timer (10 sec)
start timer (15 sec)
15 sec
10 sec

在DLL中调用了15秒的计时器并立即到期。10秒计时器在可执行文件中被调用并正常工作。

我正在与Visual Studio 2017 V15.5.2。

合作

这不是错误,在您的startTimer方法中,您创建了steady_timer对象并调用asyncWait方法,但是此方法立即返回(请参阅参考http://wwwww.boost.org/doc/doc/libs/1_53_0/doc/html/boost_asio/reference/basic_waitable_timer/async_wait.html),因此删除了计时器对象并调用处理程序(然后打印15秒)。您应该检查ec变量的值,这可能表明操作已中止。

在主函数计时器对象中起作用,因为程序在此行中等待

ioservice.run();

因此,可以在10秒后调用处理程序。