关于boost::asio相关的网络如何正确退出的问题探讨

不二星空 2017-01-18 03:47:21
boost::asio异步基于完成端口实现的一套开源的网络框架,但是在程序关闭时遇到的了一些问题,不知各位大侠有没有了解相关知识,问题如下:
目前采用先关闭socket,再关闭io_service的方式
1、如果io_service调用stop之后直接销毁,会有概率出现异常,大概的意思就是工作者线程还未退出的情况下,io_service被销毁了。但是目前没有找到对应可以控制相关顺序的方式,工作者线程不只一个。
2、socket如果调用async_connect后,调用socket.cancel()和socket.close()后,实际并未立马中止链接,实际上工作者线程需要等待超时或者中断返回,此次的async_connect才算执行完毕,有没有其他的关闭方式,能更快或者能控制时序的方式进行关闭?
望指教~~
...全文
487 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
lx624909677 2017-01-21
  • 打赏
  • 举报
回复
工作线程的退出为什么难判断,根据线程创建返回的handle来判断就可以了啊
an_bachelor 2017-01-21
  • 打赏
  • 举报
回复
加1层能解决1切。
引用 7 楼 shenyi0106 的回复:
[quote=引用 6 楼 ycf8788 的回复:] [quote=引用 4 楼 shenyi0106 的回复:] 要让工作者线程结束其实很简单,Post以一个自定义的事件进去就可以了。 难处理的是,很多已经投递(read和write)下去的操作还么有返回,你就让工作者线程退出了, 后续的内存处理可能会带来程序的崩溃。
post进去也只是post到其中一个工作者线程。并不能确保所有工作者线程都处于空闲状态。 很多投递的操作,可以中止掉,不过都是异步的,需要等待。 就是这个等待的时间就不是很好确定。暴力的办法就是固定sleep一段时间等待他们退出。[/quote] 启动了几个worker难道不记录?启动了几个worker就post几个事件进去,是能够确保worker都会正常退出的,但是是不是空闲就无法保证了。 不管是CloseHandle或者CloseSocket或者CancelIo引起的撤销IO事件,在高IO的情况下,返回时间都是很慢的,3、5秒到十多秒都是经常出现的,尤其是在多连接和高PPS的情况下,这种返回等待时间就更长,Sleep可能不会帮助你解决内存被锁定引起的Crash问题,引用计数应该是你需要考虑的方向。[/quote]
shenyi0106 2017-01-20
  • 打赏
  • 举报
回复
引用 6 楼 ycf8788 的回复:
[quote=引用 4 楼 shenyi0106 的回复:] 要让工作者线程结束其实很简单,Post以一个自定义的事件进去就可以了。 难处理的是,很多已经投递(read和write)下去的操作还么有返回,你就让工作者线程退出了, 后续的内存处理可能会带来程序的崩溃。
post进去也只是post到其中一个工作者线程。并不能确保所有工作者线程都处于空闲状态。 很多投递的操作,可以中止掉,不过都是异步的,需要等待。 就是这个等待的时间就不是很好确定。暴力的办法就是固定sleep一段时间等待他们退出。[/quote] 启动了几个worker难道不记录?启动了几个worker就post几个事件进去,是能够确保worker都会正常退出的,但是是不是空闲就无法保证了。 不管是CloseHandle或者CloseSocket或者CancelIo引起的撤销IO事件,在高IO的情况下,返回时间都是很慢的,3、5秒到十多秒都是经常出现的,尤其是在多连接和高PPS的情况下,这种返回等待时间就更长,Sleep可能不会帮助你解决内存被锁定引起的Crash问题,引用计数应该是你需要考虑的方向。
不二星空 2017-01-20
  • 打赏
  • 举报
回复
引用 4 楼 shenyi0106 的回复:
要让工作者线程结束其实很简单,Post以一个自定义的事件进去就可以了。 难处理的是,很多已经投递(read和write)下去的操作还么有返回,你就让工作者线程退出了, 后续的内存处理可能会带来程序的崩溃。
post进去也只是post到其中一个工作者线程。并不能确保所有工作者线程都处于空闲状态。 很多投递的操作,可以中止掉,不过都是异步的,需要等待。 就是这个等待的时间就不是很好确定。暴力的办法就是固定sleep一段时间等待他们退出。
不二星空 2017-01-20
  • 打赏
  • 举报
回复
引用 3 楼 zhao4zhong1 的回复:
万事开头难。 依我看,万事优雅地结束也难。
哈哈。。。是啊,想优雅的关闭也难。。。
shenyi0106 2017-01-19
  • 打赏
  • 举报
回复
要让工作者线程结束其实很简单,Post以一个自定义的事件进去就可以了。 难处理的是,很多已经投递(read和write)下去的操作还么有返回,你就让工作者线程退出了, 后续的内存处理可能会带来程序的崩溃。
赵4老师 2017-01-19
  • 打赏
  • 举报
回复
万事开头难。 依我看,万事优雅地结束也难。
不二星空 2017-01-18
  • 打赏
  • 举报
回复
引用 1 楼 VisualEleven 的回复:
你需要先退出线程,等待所有的工作线程结束,然后销毁线程使用的资源
就是工作者线程退出这点就很难判断。。。目前没找到合适的方式。
Eleven 2017-01-18
  • 打赏
  • 举报
回复
你需要先退出线程,等待所有的工作线程结束,然后销毁线程使用的资源

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧