一.今日大纲

1.multiprocessing模块简单应用

2.for循环创建进程

3.进程传参方式和创建方式2

4.join方法

5.操作系统基础

二.今日内容

    (1)操作系统简单介绍
多道技术:(超级重点)
空间复用
时间复用
进程之间是空间隔离的
分时系统
实时系统
通用操作系统(遇到io切换的会提高代码效率), 并发:又称伪并发,看着像同时运行,其实是任务之间的切换(遇到IO切换的会提高代码效率)
任务切换+保存状态(保存现场)
并行:真正的同时在运行,应用的是多核技术(多个cpu) 进程三状态:就绪(等待操作系统调度去cpu里面执行) 执行 阻塞 提交任务的方式:同步异步
任务的执行状态:阻塞非阻塞
异步:任务的提交方式,多个任务提交出去,同时执行 同步堵塞:
异步堵塞: 同步非堵塞:
异步非堵塞: (这里是开启进程) (2)进程的两种创建方式
Process(target=f1,args=(i,)) kwargs={'形参名为key':值} (3)
#例子
from multiprocessing import Process class MyProcess(Process): #继承
def __init(self,n):
super().__init__()
self.n=n def run(self):
pass
if __name__='__main__':
P=MyProcess(12)
P.start() join方法:主进程等待子进程执行结束再继续执行
没有join的话,先执行主进程中的内容
for 循环开启进程
三.详细内容
(1)multiprocessing模块简单应用:
#运行中的程序叫做进程
import time
time.sleep(1)
print('')
#操作系统是大型软件
#操作系统帮助我们调用硬件的 重点代码&重点注释分析
进程的创建方式1
import time
from multiprocessing import Process
def f1():
time.sleep(3)
print('xxx')
def f2():
time.sleep(3)
print('sss')
#f1()
#f2()
#重点理解:windows系统下必须写main,因为windows系统创建子进程的方式决定的,开启一个子进程,
# 这个子进程会copy一份主进程的所有代码,并且机制类似于import引入,这样就容易导致引入代码的时候,
# 被引入的代码中的可执行程序被执行,导致递归开始进程,会报错
if __name__=='__main__':
p1=Process(target=f1,) #子进程相当于copy主进程的内容一份
p2=Process(target=f2,)
p1.start() #先调用主程序内的,再执行自己的并且,
# 所有start必须执行完,才可以执行,
p2.start() time.sleep(3) #仅限于我们的程序
# p1.join() #意思是子进程执行完才执行主进程
# p2.join()
print('我是主进程!!') '''
不注释
p1.join()
p2.join():
结果:
xxx
sss
我是主进程!! 注释
p1.join()
p2.join():
结果:
我是主进程!!
xxx
sss
'''

(2)for循环创建进程

import time
from multiprocessing import Process def f1(i):
time.sleep(1)
print(i) if __name__=='__main__': for i in range(20):
p1=Process(target=f1,args=(i,)) #传参
p1.start()

注意:上边得到的结果是:0-19的20行数字,并且不是按照有序排列的

(3)演示两种传参方式

演示两种传参方式
方式一:
# import time
# from multiprocessing import Process
# def f1(i):
# time.sleep(3)
# print(i)
# if __name__=='__main__':
# p1=Process(target=f1,args=('冬瓜与黄瓜',)) #传参
# p1.start() #给操作系统发送一个创建进程的信号,后续进程的创建都是操作系统的事 方式二
# import time
# from multiprocessing import Process
#
# def f1(i):
# time.sleep(3)
# print(i)
# if __name__=='__main__':
# p1=Process(target=f1,kwargs={'i':'大牛'}) #传参//创建进程对象
# p1.start() #给操作系统发送一个创建进程的信号,后续进程的创建都是操作系统的事

案例:

from multiprocessing import  Process
class MyProcess(Process):
def run(self):
print('宝宝')
if __name__=='__main__':
p1=MyProcess()
p1.start()

(4)进程的创建方式2

#传参:需要重新写一个init方法
from multiprocessing import Process
class MyProcess(Process):
def __init__(self,n):
super().__init__() #先执行父类的方法
#别忘了执行父类的init
''''''
'''
没有上面的一句话,会报错,原因是下面,所以必须继承父类的参数
assert self._popen is None, 'cannot start a process twice'
AttributeError: 'MyProcess' object has no attribute '_popen'
'''
self.n=n #自己定义的形式参数n def run(self):
print('宝宝and%s不可告人的事情'%self.n)
if __name__=='__main__':
p1=MyProcess('搞忘')
p1.start()

(5)join方法

import time
from multiprocessing import Process
def f1():
time.sleep(2)
print('xxxx')
def f2():
time.sleep(2)
print('ssss')
# f1()
# f2()
if __name__ == '__main__': p1 = Process(target=f1,)
p1.start()
p1.join() # 主进程等待子进程运行完才继续执行 print('开始p2拉') #这个地方相当于主进程 p2 = Process(target=f2,)
p2.start()
p2.join()
print('我要等了...等我的子进程...')
time.sleep(3)
print('我是主进程!!!') '''
如果把两个join()方法注释掉,结果是:
开始p2拉
我要等了...等我的子进程...
xxxx
ssss
我是主进程!!! 不注释的结果是:
xxxx
开始p2拉
ssss
我要等了...等我的子进程...
我是主进程!!!
												

并发编程5 操作系统&进程的更多相关文章

  1. Python3 与 C# 并发编程之~进程先导篇

      在线预览:http://github.lesschina.com/python/base/concurrency/1.并发编程-进程先导篇.html Python3 与 C# 并发编程之- 进程篇 ...

  2. Python并发编程01 /操作系统发展史、多进程理论

    Python并发编程01 /操作系统发展史.多进程理论 目录 Python并发编程01 /操作系统发展史.多进程理论 1. 操作系统 2. 进程理论 1. 操作系统 定义:管理控制协调计算机中硬件与软 ...

  3. 多并发编程基础 之进程 Process

    原贴  https://www.cnblogs.com/gbq-dog/p/10299663.html 1. 进程的理论知识 1.1 操作系统的背景知识 顾名思义,进程即正在执行的一个过程.进程是对正 ...

  4. python 之 并发编程(守护进程、互斥锁、IPC通信机制)

    9.5 守护进程 主进程创建守护进程 其一:守护进程会在主进程代码执行结束后就立即终止 其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic process ...

  5. 并发编程,python的进程,与线程

    并发编程 操作系统发展史 基于单核研究 多道技术 1.空间上的复用 多个程序公用一套计算机硬件 2.时间上的复用 切换+保存状态 例子:洗衣 烧水 做饭 切换 1.程序遇到IO操作系统会立刻剥夺走CP ...

  6. Java并发编程:线程和进程的创建(转)

    Java并发编程:如何创建线程? 在前面一篇文章中已经讲述了在进程和线程的由来,今天就来讲一下在Java中如何创建线程,让线程去执行一个子任务.下面先讲述一下Java中的应用程序和进程相关的概念知识, ...

  7. Python3 与 C# 并发编程之~ 进程篇

      上次说了很多Linux下进程相关知识,这边不再复述,下面来说说Python的并发编程,如有错误欢迎提出- 如果遇到听不懂的可以看上一次的文章:https://www.cnblogs.com/dot ...

  8. python 并发编程 多进程 守护进程

    一 守护进程 主进程创建子进程目的是:主进程有一个任务需要并发执行,那开启子进程帮我并发执行任务 主进程创建子进程,然后将该进程设置成守护自己的进程 关于守护进程需要强调两点: 其一:守护进程会在主进 ...

  9. python并发编程之守护进程、互斥锁以及生产者和消费者模型

    一.守护进程 主进程创建守护进程 守护进程其实就是'子进程' 一.守护进程内无法在开启子进程,否则会报错二.进程之间代码是相互独立的,主进程代码运行完毕,守护进程也会随机结束 守护进程简单实例: fr ...

随机推荐

  1. IOS 拍照旋转修正

    - (UIImage *)fixOrientation:(UIImage *)aImage { // No-op if the orientation is already correct if (a ...

  2. Atitit.执行cmd 命令行 php

    Atitit.执行cmd 命令行 php 1. 执行cmd 命令行,调用系统命令的基础 1 1.1. 实际执行模式 1 1.2. 空格的问题 1 1.3. 中文路径的问题,程序文件读取编码设置 1 1 ...

  3. python学习之find()

    定义: find() 方法检测字符串中是否包含子字符串 str ,如果指定 beg(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,如果包含子字符串返回开始的索引值,否则返回-1. 语法 ...

  4. Mysql bin-log日志文件处理

    当MySQL开启bin-log选项后,会不停的记录bin-log,但是几天前的日志肯定就没用了或者可以备份到别处,那么如何正确的处理这些日志呢 参考一下几篇文章 MySQL mysql-bin log ...

  5. linux学习笔记18--文件/chmod/chown/chgrp

    文件类型与扩展名: Linux文件类型和Linux文件的文件名所代表的意义是两个不同的概念.我们通过一般应用程序而创建的比如file.txt.file.tar.gz ,这些文件虽然要用不同的程序来打开 ...

  6. linux学习笔记16--命令find

    find是linux系统中用的比较多的一个命令,而且功能强大,特别是对各种查找方式的不确定位置的文件的查找. Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提 ...

  7. bootstrap table 服务器端分页--ashx+ajax

    1.准备静态页面 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-T ...

  8. linux设置时间的方法

    0. date -R  中国上海的时区是+8000 1.tzselect 设置时区,依次选择5,9,1,1(如果时区不一样,执行下面的命令得到之后时间是不一样的) 2.sudo ntpdate asi ...

  9. windows hosts 作用以及常见问题解决

    借用百度百科的解释 Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,当用户在浏览器中输入一个需要登录的网址时,系统 ...

  10. php 区分中文,英文,中英混合

    $str1="是你"; $strA = trim($str1); $lenA = strlen($strA); $lenB = mb_strlen($strA,"utf- ...