python实现多任务解析

多任务

多任务

现实中,有很多事情是同时进行的。比如一个歌手一边唱歌,一边跳舞。唱歌与跳舞是同时进行的,如果将这两件事分开进行就显得很尴尬了...

用python来描述唱歌与跳舞这两件事:

from time import sleep
def sing():
    for i in range(3):
        print("singing...%d" % i)
        sleep(1)

def dance():
    for i in range(3):
        print("dancing...%d" % i)
        sleep(1)

if __name__ == '__main__':
    sing()
    dance()

# singing...0
# singing...1
# singing...2
# dancing...0
# dancing...1
# dancing...2

显然,以上的程序不能满足同时唱歌与跳舞的需求,而是先唱歌,后再尬舞

要实现唱歌与跳舞同时执行,就必须用到多任务

所谓多任务,就是操作系统可以同时运行多个任务。比如一边听音乐,一边码代码,一边开着浏览器...

这些任务看起来是并行在执行。可实际上这些任务是在交替执行的,因为任务的数量远多于CPU的核数,而每核CPU在同一时间只能执行一个任务。由于CPU的执行速度很快,在我们看来就好像所有任务在同时执行一样

进程

对于操作系统而言,多任务就是执行多个进程。

所谓进程,就是指正在运行中的代码。

python的os模块封装了常见的系统调用,可以轻松地用fork()方法创建子进程:

import os
pid = os.fork()
if pid == 0:
    print('我在唱歌')
else:
    print('我在尬舞')

# 我在尬舞
# 我在唱歌

代码执行说明:

  • 程序在执行到os.fork()时,操作系统会创建一个新的进程(子进程),然后复制父进程的所有信息到子进程中
  • 父进程和子进程都会从fork()中得到一个返回值,在子进程中这个值一定是0,而父进程中是子进程的id号

fork

普通的函数调用,调用一次,返回一次,但是fork()调用一次,返回两次,因为操作系统自动把当前进程(父进程)复制了一份(子进程),然后分别在父进程和子进程内返回

一个父进程可以fork出很多子进程,父进程要记下每个子进程的id,而子进程可通过调用getppid()拿到父进程的id

import os
rpid = os.fork()
if rpid < 0:
    print("fork调用失败")
elif rpid == 0:
    print("我是子进程(%s), 我的父进程是(%s)" % (os.getpid(), os.getppid()))

else:
    print("我是父进程(%s), 我的子进程是(%s)" % (os.getpid(), rpid))

print('父子进程都可以执行这里的代码')

# 我是父进程(2291), 我的子进程是(2292)
# 父子进程都可以执行这里的代码
# 我是子进程(2292), 我的父进程是(2291)
# 父子进程都可以执行这里的代码

源码下载

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏移动应用测试

当uiautomator遇到xpath和ocr,畅快

Android 的 UI 测试中,经常要点击某个控件,google 给出了 uiautomator 工具可以方便的查看控件信息,但是写测试用例的时候,仍然经常遇...

1274
来自专栏AzMark

Python 学习之 Tkinter「上 」

1123
来自专栏前端小吉米

打造多线程 Web

853
来自专栏我的博客

UBB原理-用于替换部分html标签

ubb这种代码正则表达式来进行匹配,不同的论坛所使用的UBB代码很可能不同,不能一概而论。UBB代码的出现,使得论坛可以使用类似HTML的标签来增加文字的属性,...

2736
来自专栏Spark学习技巧

细谈CAS与ABA

题目:如何实现乐观锁(CAS),如何避免ABA问题? 本文阅读大概需要15分钟。 这个题主要考查原子操作、悲观锁、乐观锁及ABA问题。 一 原子操作 原子在化...

3085
来自专栏FreeBuf

Android漏洞CVE-2015-3825分析及exploit实战:从Crash到劫持PC

* 本文原创作者: thor@MS509Team,本文属FreeBuf原创奖励计划,未经许可禁止转载 CVE-2015-3825是去年Android系统爆出的高...

2336
来自专栏程序员的SOD蜜

在SQLMAP中使用动态SQL

最近有几个同事和朋友询问如何在SQLMAP中“拼接字符串”,因为有时候条件的数量不固定,条件参数类型也不固定,无法写出 @参数名 这样的SQL语句,也就是大家常...

2069
来自专栏前端达人

2018年最全面的前端面试题都在这里了

意义:根据内容的结构化(内容语义化),选择合适的标签(代码语义化)便于开发者阅读和写出更优雅的代码的同时让浏览器的爬虫和机器很好地解析。 注意: 1.尽可能少的...

1574
来自专栏三丰SanFeng

Linux进程间通信(IPC)机制总览

Linux进程间通信 Ø 管道与消息队列 ü 匿名管道,命名管道 ü 消息队列 Ø 信号 ü 信号基础 ü 信号应用 Ø 锁与信号灯 ü 记录锁 ü 有名信号灯...

18910
来自专栏java学习

每日一练(2017/5/15)

Java基础 | 数据库 | Android | 学习视频 | 学习资料下载 课前导读 ●回复“每日一练”获取以前的题目! ●答案公布时间:为每期发布题目的第二...

2677

扫码关注云+社区