从另一个线程将recvfrom从阻塞状态唤醒
2012-02-28 12:51
267 查看
UDP的多线程程序,一般开一个线程循环调用recvfrom接收消息,当程序中止的时候,如果这个线程阻塞在recvfrom调用,并且没有消息到达,则这个线程无法终止,造成资源泄露等问题。
这里终止这个线程有六种方法:
1. 释放监听的fd,这个是最简单的方法,但是有一点要注意,就是close(fd)系统调用无效,必须要使用shutdown(fd, SHUT_RDWR)来将recvfrom唤醒,因为close只关闭写通道,recvfrom在fd的写通道等待列表中,只要关闭写通道时才会将recvfrom阻塞唤醒。
2. 在调用recvfrom前将recvfrom的fd设置一个超时,这个超时时间较难设置,但比较简单,也容易实现
3. 在调用recvfrom前将recvfrom的fd设置为非阻塞的,这个方法容易导致循环过快,CPU使用率上升
4. 使用select/epoll来接收,
5. fake一个消息包发给这个相应的端口
6. pthread_cancel强制杀掉线程
这里终止这个线程有六种方法:
1. 释放监听的fd,这个是最简单的方法,但是有一点要注意,就是close(fd)系统调用无效,必须要使用shutdown(fd, SHUT_RDWR)来将recvfrom唤醒,因为close只关闭写通道,recvfrom在fd的写通道等待列表中,只要关闭写通道时才会将recvfrom阻塞唤醒。
2. 在调用recvfrom前将recvfrom的fd设置一个超时,这个超时时间较难设置,但比较简单,也容易实现
3. 在调用recvfrom前将recvfrom的fd设置为非阻塞的,这个方法容易导致循环过快,CPU使用率上升
4. 使用select/epoll来接收,
5. fake一个消息包发给这个相应的端口
6. pthread_cancel强制杀掉线程
相关文章推荐
- 从另一个线程将recvfrom从阻塞状态唤醒
- 阻塞和唤醒线程——LockSupport功能简介及原理浅析
- 如何结束阻塞状态的线程
- Java线程唤醒与阻塞
- 关于Java线程状态转换中的wait()被唤醒时进入的状态的疑问
- 多线程:线程状态、synchronized关键字、读写锁、条件对象、Volatile、阻塞队列等小结
- SB了,pthread_cond_wait(),在等待的时候会解锁(阻塞之后,解锁mutex给别的线程),唤醒后加锁,
- 初见Java多线程(三、线程的阻塞状态)
- Java线程唤醒与阻塞
- 从JDK源码角度看线程的阻塞和唤醒
- 使用Interlocked在多线程下进行原子操作,无锁无阻塞的实现线程运行状态判断
- 线程状态与停止、阻塞(join、yield、sleep)、基本信息、优先级JAVA174-177
- java线程阻塞唤醒的四种方式
- 从JDK源码角度看线程的阻塞和唤醒
- 线程五种状态(新建、就绪、运行、阻塞、死亡)
- 线程的状态与阻塞的方法
- java面试--多线程 基本理解 (线程5个状态如何变化?还有等待、阻塞、让步等如何形成的?)
- 线程的生命周期---运行和阻塞状态
- 进程线程的调度阻塞唤醒
- 线程状态与停止、阻塞(join、yield、sleep)、基本信息、优先级JAVA174-177