Python进程线程管理:非阻塞套接字与多任务控制
需积分: 5 61 浏览量
更新于2024-08-05
收藏 3KB MD 举报
"进程线程补充"
在计算机科学中,进程和线程是操作系统中并发执行的基本单位。本文档主要补充了关于进程线程的一些关键知识点,并提供了如何处理阻塞情况、多任务运行控制以及多任务标志的示例。
### 1. 阻塞与非阻塞以及io多路复用
#### (1) 阻塞与非阻塞套接字
在使用`socket`进行数据传输时,可能会遇到两处阻塞点:
1. 服务端`accept`时,如果客户端尚未`connect`,服务端会一直等待,处于阻塞状态。
2. 当客户端已经连接,但`conn`在等待`recv`数据时,如果客户端没有发送数据,也会阻塞。
#### (2) 解决阻塞的策略
- **非阻塞套接字**:通过`setblocking(False)`设置套接字为非阻塞模式,当遇到阻塞情况时,不会等待而是立即返回错误,通过异常处理机制来处理这种情况。
- **IO多路复用**:如`epoll`,通过`register`注册感兴趣的事件,`events_read`监听事件,当事件发生时调用回调函数,避免单个套接字阻塞整个程序。
- **多进程**:使用`multiprocessing`库,每个进程拥有独立的内存空间,可以并行处理不同的请求,避免阻塞。
- **多线程**:使用`threading`库,尽管线程之间共享内存,但在某些情况下可以提高并发性能,但需注意资源抢占问题。
### 2. 多任务运行控制
#### (1) 主进程等待子进程结束后再结束
- 使用`join()`方法,例如`p1.join()`,主进程会等待`p1`子进程执行完毕后再继续执行。
#### (2) 主进程结束,子进程强制终止
- 使用`terminate()`方法,例如`p1.terminate()`,主进程可以强制终止子进程,不等待其自然结束。
#### (3) 检查进程状态
- 使用`multiprocessing.current_process()`可以获取当前运行的进程信息。
### 3. 多任务标志
#### (1) 进程PID
- 可以通过`pid`属性获取进程ID,例如`print('beforestart:', p1.pid)`。
#### (2) 线程的`ident`
- 线程的唯一标识符可以通过`ident`属性获取,例如`print('beforestart:', t.ident)`。
#### (3) 进程线程名字
- 初始化进程或线程时可以指定名字,例如`p1 = multiprocessing.Process(target=func, args=(1,), name='进程1号')`。
- 运行后可以通过`name`属性查看,或者修改名字,如`p1.name = '进程1号'`。
同样的,线程的命名也类似,可以通过`threading.Thread(target=func, args=(1,), name='线程1号')`实例化并命名线程,之后可使用`t.name`访问或修改。
总结,进程和线程的管理对于实现高效的并发程序至关重要。了解如何处理阻塞、控制任务执行顺序以及标识和监控进程线程是编写并发程序的基础。合理地使用多进程和多线程可以极大地提升程序的执行效率,同时需要注意进程间通信和同步问题,以防止数据竞争和死锁的发生。
416 浏览量
点击了解资源详情
102 浏览量
2024-01-19 上传
2022-08-03 上传
2023-07-30 上传
243 浏览量
2021-09-28 上传
从零开始菜鸟☞辉
- 粉丝: 2
- 资源: 23
最新资源
- 速卖通运费模板快速设置神器.zip
- PersonalWebsite:个人网站
- Genre-ist:音乐体裁检测
- Challanges:Challanges在edabit中解决
- chatterbox-client
- code-generator.rar
- flutter_workout:使用Flutter构建健身应用程序。 目标是重新创建锻炼伙伴,但实际上
- 时尚生活日志响应式网站模板
- mb-works-2.0
- 我的待办事项:to to app
- jquery图片点击翻转效果(类似扑克牌翻转)
- bank_JS:允许用户创建银行账户并存入或提取资金的应用程序
- 精彩日志动态展示响应式网站模板
- 克米discuz X2.5/X3.0多城市分类顶部显示插件
- AngryWithPlatform
- react_with_sockets