- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在我的应用程序中使用 UDP 客户端-服务器进行 IPC
它工作正常,但是当尝试关闭客户端时会发生一些竞争条件,这会导致应用程序崩溃或死锁。
UDP 客户端:
// IOServiceBase class contain boost::asio::io_service instance
// it is accessible by service() protected method
class AsyncUDPClient : public IOServiceBase
{
public:
/// @brief Create a network client
AsyncUDPClient(const std::string& host, const std::string port)
: _host(host)
, _port(port)
, _reply()
, _work(service())
, _sock(service(), ba_ip::udp::endpoint(ba_ip::udp::v4(), 0)) {
run();
}
/// @brief Start async packets processing
void run(){
std::thread t([&]{ service().run(); });
t.detach();
}
/// @brief Async request to server
void send(uint8_t* message, size_t length) {
std::vector<uint8_t> packet(message, message + length);
service().post(boost::bind(&AsyncUDPClient::do_send, this, packet));
}
/// @brief Cleanup io_service to dismiss already putted tasks
~AsyncUDPClient() {
close();
// trying to wait until service is stopped, but it does not help
while (!service().stopped()){
std::this_thread::sleep_for(std::chrono::milliseconds(100));
}
}
/// @brief Cleanup io_service to dismiss already putted tasks
void close(){
std::thread t([&]{ service().stop(); });
t.join();
}
protected:
// send-response methods are pretty standard
private:
std::string _host;
std::string _port;
std::array<uint8_t, max_length> _reply;
ba::io_service::work _work;
ba_ip::udp::socket _sock;
};
使用示例:
{
AsyncUDPClient ipc(addr, port);
ipc.send(&archive_data[0], archive_data.size());
// it seems client is destroyed before some internal processing is finished?
}
行为不是确定性的,有时工作正常,有时崩溃,有时死机。Stacktrace 显示 boost.asio 内部某处的崩溃点
最佳答案
AsyncUDPClient
的破坏未与运行 io_service
的线程正确同步。当处理 io_service
的线程在其生命周期结束后尝试与 AsyncUDPClient
及其 io_service
交互时,这可能会导致调用未定义的行为。
要解决此问题,请不要从处理 io_service
的线程分离,并在 io_service
停止后显式加入线程。
class AsyncUDPClient
: public IOServiceBase
{
public:
// ...
void run()
{
_threads.emplace_back([&]{ service().run(); })
}
// ...
~AsyncUDPClient()
{
close();
}
void close()
{
// Stop the io_service. This changes its state and return immediately.
service().stop();
// Explicitly synchronize with threads running the io_service.
for (auto& thread: _threads)
{
thread.join();
}
}
private:
// ...
std::vector<std::thread> _threads;
};
正如上面评论中所暗示的,io_service::stop()
不阻止。它将 io_service
的状态更改为已停止,立即返回,并导致 run()
和 run_one()
的所有调用尽快返回可能的。调用 io_service::stopped()
立即返回 io_service
的状态。这些调用均未指示 run()
或 run_one()
调用中当前是否存在线程。
关于c++ - Boost Asio,异步 UDP 客户端 - 关机时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29982513/
在我的 root 用户 android 应用程序上,我使用 执行关机 su reboot -p 它工作正常,但我注意到手机几乎立即关机(而不是显示关机动画,并且可能在做其他事情)。 这是以编程方式关闭
我想创建一个流量小部件,并在每次设备关闭时存储使用的流量。问题是我无法触发关闭接收器。 我使用了以下代码: IntentFilter actionShutdown = new IntentFi
前言 RTC RTC 即实时时钟(Real-Time Clock),主要是功能有: 时间保持:RTC可以在断电的时候,仍然保持计时功能,保证时间的连续性 时间显示与设置:RTC可以向系
我在网上发现我可以安排 Windows 关闭: private void button1_Click(object sender, EventArgs e) { // Shutdown
是我可以调用的任何方法,它返回给我的信息是电话实际要关机(关机)。我知道这是 ACTION_SHUTDOWN 的 Intent ,但我必须从另一个来源获取有关关闭电话的信息。最好是直接形成系统。可能会
有没有办法在终止时运行代码,无论终止是什么类型(异常、正常、未捕获的异常等)?我知道它在 Java 中实际上是可能的,但它甚至可能在 C++ 中吗?我假设是 Windows 环境。 最佳答案 不——如
我希望我的应用程序可以防止 Windows 关闭。我知道有一个系统命令可以做到这一点。但不适用于我的程序。我使用此代码“取消”关闭的窗口: private void Form1_FormClosing
如何为我的应用暂停足够长的关机时间?我找到了一个 example ,但它适用于 Delphi - 我无法将其翻译成 C++。 最佳答案 这是 Delphi 代码的 C++Builder VCL 翻译:
我想知道当某个软件需要重新启动、关闭、注销或休眠 Windows 时,最佳做法是什么: 使用ExitWindowsEx API 使用关机命令及其参数 每种方法的优点和缺点是什么? 谢谢 最佳答案 我总
当我在虚拟机运行时尝试关闭 Windows 时,VMWare Workstation 的表现非常酷: 通常,我们会看到“此程序正在阻止 Windows 关闭”消息,而不是新的“1 个虚拟机正在使用中”
1、注销,关机,重启 注销系统的logout命令 1,Logout 注销是登陆的相对操作,登陆系统后,若要离开系统,用户只要直接下达logout命令即可: [root@localhost r
php 里面有个 system 方法, 可以调用系统命令。 先建立一个脚本(比喻 /root/reboot_server.sh ),重启用的。 复制代码代码如下: #!
我在戴尔 5000 游戏系列上安装了 Ubuntu 18.04,安装正常,然后在安装后提示重新启动。 重新启动登录屏幕后,我输入密码(为我在安装过程中创建的帐户)并按回车,但屏幕变为粉红色,几秒钟后它
我需要能够实现方法来防止这些情况发生: 关机 重启 注销 sleep 在 Mac 上,我使用的是 Xcode,但似乎无法找出执行这些操作的代码。 有人可以帮我从这里出去吗? 我发现了这个:http:/
我正在开发应用程序,我有一个要求:如果用户在任何时候长按电源按钮并再次按下以启动设备, Activity 应该从设备关闭的地方开始。我也不知道这个是不是一个有效的问题。我尝试使用: public cl
是否可以在所有网络接口(interface)停止之前检测到 Linux 中的系统关闭/重启?我可以处理 SIGTERM 信号并检查运行级别,但此时网络可能已经关闭。我需要 Python 脚本中的功能。
我目前正在开发一个小型但基本的应用程序,使用 tkinter 在我的 Windows 启动上运行,这样我就可以为我想要打开的不同内容提供一个小菜单。例如,我目前有启动我玩的一些游戏的按钮以及启动 Sk
我知道 shutdown -a 会中止 Windows 关机,但我需要知道是否有任何地方可以检查是否正在进行关机。 理想情况下,我想要一个像这样的小程序: import os while True
我试图在我的 c 程序中检测 Linux 的关闭或重启。我发现程序可以使用 signal(SIGTERM, handler) (SIGKILL, handler)。但是如果用户也使用命令终止进程,这两
我有这个工作的 Windows Server 2012 VM,需要重新启动。在我重新启动虚拟机后,更改了一些设置(连接了一个 DVD 驱动器),它会再次启动。 现在它说: Failed - The a
我是一名优秀的程序员,十分优秀!