一、进程

1.1、方式一

from multiprocessing import Process
import time #方式一
def task(name):
print(f"my name is {name},启动时间")
time.sleep(2)
print(f"my name is {name},停止时间") if __name__ == '__main__':
# 1 创建一个对象
p = Process(target=task, args=('jason',))
# 容器类型哪怕里面只有1个元素 建议要用逗号隔开 args=('jason',)
# 2 开启进程
p.start() # 告诉操作系统帮你创建一个进程 异步
print('主进程')
'''
Windows操作系统下,创建进程一定要在main中创建
因为Windows下创建的进程类似于模块导入的方式
代码会从上往下依次执行
'''

1.2、方式二

class MyProcess(Process):
def run(self):
print('hello bf girl')
time.sleep(1)
print('get out!') if __name__ == '__main__':
p = MyProcess()
p.start()
print('主进程')

总结:

  • 创建进程就是在内存中申请一块内存空间将需要运行的代码丢进去
  • 一个进程对应在内存中就是一块独立的内存空间
  • 多个进程对应在内存中就是多块独立的内存空间
  • 进程与进程之间数据默认情况下是无法直接交互,如果想交互可以借助于第三方工具、模块

1.3、join方法

  • join是让主进程等待子进程代码运行结束之后,再继续运行。不影响其他子进程的执行
from multiprocessing import Process
import time def task(name, n):
print('%s is running'%name)
time.sleep(n)
print('%s is over'%name) if __name__ == '__main__':
# p1 = Process(target=task, args=('x', 1))
# p2 = Process(target=task, args=('c', 2))
# p3 = Process(target=task, args=('v', 3))
# start_time = time.time()
# p1.start()
# p2.start()
# p3.start() # 仅仅是告诉操作系统要创建进程
# p.join() # 主进程等待子进程p运行结束之后再继续往后执行
# p1.join()
# p2.join()
# p3.join()
start_time = time.time()
p_list = []
for i in range(1, 4):
p = Process(target=task, args=('子进程%s'%i, i))
p.start()
p_list.append(p)
for p in p_list:
p.join()
print('主', time.time() - start_time)

1.4、进程之间数据相互隔离

from multiprocessing import Process
money = 100
def task():
global money # 局部修改全局
money = 666
print('子',money)
if __name__ == '__main__':
p = Process(target=task)
p.start()
p.join()
print(money)

最新文章

  1. JS 日期格式化和解析工具
  2. Request is not available in this context
  3. Java 创建xml文件和操作xml数据
  4. Oracle EBS PO 收接事处理状态待定或错误
  5. Stable Matching 稳定匹配 婚姻算法 shapley 算法
  6. C#中的反射 Assembly.Load() Assembly.LoadFrom()
  7. SharePoint Dialog 使用
  8. 学习springMVC实例1——配置和跳转到HelloWorld
  9. dede 标签
  10. win8.1 64位+oracle11g R2 64位 +powerdesigner破解版 64位+PL/SQL
  11. gradle 将依赖打入Jar包的方法
  12. thinkpad 睡眠唤醒后热键功能正常,但屏幕无法显示状态/进度条/图标
  13. GridView有用的小方法--2017年2月13日[转]
  14. FPGA驱动步进电机
  15. 洛谷p1091合唱队形题解
  16. ModuleNotFoundError: No module named 'requests'
  17. 重识linux-linux的新增与删除用户组和切换命令
  18. linux分区满了,如何进行扩容
  19. 10.十进制转m进制
  20. windows中查看端口被什么应用程序占用并删除

热门文章

  1. django学习(三)
  2. Johnson全源最短路
  3. Charles安装教程
  4. 13_Python的面向对象编程-类class,对象object,实例instance
  5. flume读取日志文件并存储到HDFS
  6. ui自动化--鼠标操作ActionChains
  7. shell进行微信报警的简单应用
  8. os.walk模块查找目录下的所有txt文件
  9. Java 合并、拆分PPT幻灯片
  10. [LeetCode]105. 从前序与中序遍历序列构造二叉树(递归)、108. 将有序数组转换为二叉搜索树(递归、二分)