专栏首页python3python之操作系统介绍,进程的创建

python之操作系统介绍,进程的创建

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

操作系统简单介绍:

  多道程序设计技术

    空间复用

    时间复用

    进程之间是空间隔离的

  分时系统

  实时系统

  通用操作系统

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

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

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

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

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

 分类:

  同步阻塞

  异步阻塞:

  异步非阻塞:

  同步非阻塞:

进程的2种创建方式:

第一种:

import time
from multiprocessing import Process

def 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 Process
class MyProcess(Process):
    def __init__(self,n):
        super().__init__()  #别忘了执行父类的init
        self.n = n
    def run(self):
        print('%s快要睡着了'%self.n)

if __name__ == '__main__':
    p1 = MyProcess('大力')
    p1.start()

 传参方式:

from multiprocessing import Process
# 演示两种传参方式
def f1(n):
    print(n)

if __name__ == '__main__':
    # p1 = Process(target=f1,args=('大力',)) #创建进程对象
    p1 = Process(target=f1,kwargs={'n':'大力'}) # 创建进程对象    kwargs={函数中的形参作为key:值}
    p1.start()  #给操作系统发送了一个创建进程的信号,后续进程的创建都是操作系统的事儿了

for 循环创建进程:

import time
from multiprocessing import Process

def 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 time
from multiprocessing import Process

def 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('我是主进程!!!')

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python3--函数名本质,函数嵌套,闭包,装饰器

    函数的嵌套无非就是搞清楚函数的执行顺序(不清楚可以看前面的python全栈开发10)

    py3study
  • python 获取网络时间及修改本地时间

     本本经常时间错乱,偶闲暇之作,专为同步本本时间。以前有朋友提到日期时间设置里面的有些时间服务器。限于不同的网络,有时候这些时间服务器不一定能用。因此这次选择...

    py3study
  • Python prettytable模

    py3study
  • delete与delete[]的区别

    一直对C++中的delete和delete[]的区别不甚了解,今天遇到了,上网查了一下,得出了结论。做个备份,以免丢失。

    瑾诺学长
  • MySQL 聚簇索引 二级索引 辅助索引(上两期中奖名单)

    MySQL中每个表都有一个聚簇索引( clustered index ),除此之外的表上的每个非聚簇索引都是二级索引,又叫辅助索引( secondary ind...

    java乐园
  • Elasticsearch-py 2.3版本的API翻译文档(一)

    |hosts|我们应该连接的节点列表。节点应该是一个字典({“host”:“localhost”,“port”:9200}),整个字典将作为kwargs传递给C...

    wangchonglie
  • 我后悔在简历上写了“精通”…

    前言:众所周知,简历上“了解=听过名字;熟悉=知道是啥;熟练=用过;精通=做过东西”,我现在十分后悔在简历上写了“精通”二字…

    小灰
  • Java面试中常问的数据库方面问题

    B+树是一个平衡的多叉树,从根节点到每个叶子节点的高度差值不超过1,而且同层级的节点间有指针相互链接,是有序的

    lyb-geek
  • Java面试中常问的数据库方面问题

    B+树是一个平衡的多叉树,从根节点到每个叶子节点的高度差值不超过1,而且同层级的节点间有指针相互链接,是有序的

    Spark学习技巧
  • Java面试中常问的数据库方面问题

    B+树是一个平衡的多叉树,从根节点到每个叶子节点的高度差值不超过1,而且同层级的节点间有指针相互链接,是有序的

    Java团长

扫码关注云+社区

领取腾讯云代金券