博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python之操作系统介绍,进程的创建
阅读量:5067 次
发布时间:2019-06-12

本文共 2047 字,大约阅读时间需要 6 分钟。

操作系统(英语:operating system,缩写作 OS)是管理计算机硬件与软件资源的计算机程序,同时也是计算机系统的内核与基石。操作系统需要处理如管理与配置内存、决定系统资源供需的优先次序、控制输入与输出设备、操作网络与管理文件系统等基本事务。操作系统也提供一个让用户与系统交互的操作界面。

操作系统简单介绍:

  多道程序设计技术

    空间复用

    时间复用

    进程之间是空间隔离的

  分时系统

  实时系统

  通用操作系统

并发:伪并行,看着像同时运行,其实是任务之间的切换(遇到io切换的会提高代码效率) ,任务切换+保存状态(保存现场)

并行:真正的同时在运行,应用的是多核技术(多个cpu)

 

进程三状态:就绪(等待操作系统调度去cpu里面执行)      执行  阻塞

 

 

提交任务的方式:同步异步   任务的执行状态:阻塞非阻塞

  异步:任务的提交方式,多个任务提交出去,同时执行

 分类:

  同步阻塞

  异步阻塞:

  异步非阻塞:

  同步非阻塞:

进程的2种创建方式:

第一种:

import timefrom multiprocessing import Processdef f1():    time.sleep(3)    print('我同桌是猪')    print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()))def f2():    time.sleep(3)    print('还偷偷睡觉')    print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime()))if __name__ == '__main__':    p1 = Process(target=f1,)    p2 = Process(target=f2, )    p1.start()    p2.start()

 

 

 第二种方式: 创建一个类,继承Process

from multiprocessing import Processclass MyProcess(Process):    def __init__(self,n):        super().__init__()  #别忘了执行父类的init        self.n = n    def run(self):        print('%s快要睡着了'%self.n)if __name__ == '__main__':    p1 = MyProcess('Jerry')    p1.start()

 

 传参方式:

from multiprocessing import Process# 演示两种传参方式def f1(n):    print(n)if __name__ == '__main__':    # p1 = Process(target=f1,args=('Jerry',)) #创建进程对象    p1 = Process(target=f1,kwargs={'n':'Jerry'}) # 创建进程对象    kwargs={函数中的形参作为key:值}    p1.start()  #给操作系统发送了一个创建进程的信号,后续进程的创建都是操作系统的事儿了

 

for 循环创建进程:

import timefrom multiprocessing import Processdef f1(i):    time.sleep(3)    print(i)if __name__ == '__main__':    for i in range(20):        p1 = Process(target=f1,args=(i,))        p1.start()

 

join()方法:主进程等待子进程运行完才继续执行

import timefrom multiprocessing import Processdef f1():    time.sleep(2)    print('我是f1')def f2():    time.sleep(2)    print('我是f2')if __name__ == '__main__':    p1 = Process(target=f1,)    p1.start()    p1.join()  # 主进程等待子进程运行完才继续执行        print('p2来了')    p2 = Process(target=f2,)    p2.start()    p2.join()        print('我要等了...等我的子进程...')    print('我是主进程!!!')

转载于:https://www.cnblogs.com/selina1997/p/10240873.html

你可能感兴趣的文章
Hello China操作系统STM32移植指南(一)
查看>>
cocos2dx CCEditBox
查看>>
VC++2012编程演练数据结构《8》回溯法解决迷宫问题
查看>>
第一阶段冲刺06
查看>>
WIN下修改host文件并立即生效
查看>>
十个免费的 Web 压力测试工具
查看>>
ckeditor 粘贴后去除html标签
查看>>
面试题
查看>>
51Nod:活动安排问题之二(贪心)
查看>>
EOS生产区块:解析插件producer_plugin
查看>>
数据库框架的log4j日志配置
查看>>
lintcode-easy-Remove Element
查看>>
mysql 根据地图 坐标 查询 周边景区、酒店
查看>>
mysql重置密码
查看>>
jQuery轮 播的封装
查看>>
一天一道算法题--5.30---递归
查看>>
switchcase的用法
查看>>
React.js 小书 Lesson15 - 实战分析:评论功能(二)
查看>>
Java基础03 构造器与方法重载
查看>>
Redis 主从集群搭建及哨兵模式配置
查看>>