Python学习笔记九
Python学习笔记之九
为什么要有操作系统
管理硬件,提供接口。
管理调度进程,并且将多个进程对硬件的竞争变得有序。
操作系统发展史
第一代计算机:真空管和穿孔卡片
没有操作系统,所有的程序设计直接操控硬件
优点:程序员独享整个资源
缺点:浪费资源
第二代计算机:晶体管和批处理系统
优点:计算机资源利用
缺点:程序员共享资源,出现问题,找不出问题,影响开发效率
第三代计算机:集成电路芯片和多道程序设计
多道程序:cpu执行程序的过程中遇到I/O,不会原地等待,cpu会去执行其他命令,等到程序执行完I/O.(时间上的复用)
实现一个看起来像并发。CPU随时切换进程。会影响CPU执行效率。
进程占用一个内存空间,每个进程的内存空间,是隔离的。(空间上的复用)
第四代计算机:个人计算机
多道技术:
产生背景:针对单核,实现并发。
空间复用:内存空间是隔离的
时间复用:遇到I/O就切,提高效率
遇到运行时间过长,不提高效率
并发与并行
并发:伪并行,单个CPU+多道技术,看起来像同时运行。
并行:多个CPU才能实现并行
windows和linux创建进程:
windows: createprocess创建进程的接口
linux: fork创建进程的接口
创建子进程:
linux:子进程是父进程的完整副本,
windows:父进程与子进程的内存地址有所不同
进程状态:
运行
阻塞:碰到I/O,便要让出CPU让其他进程执行,保证CPU一直在工作。
就绪:时刻准备着运行
开启进程的两种方式:
为什么开启子进程就实现了并发?
开启子进程就为了执行自己的任务,而不会因为父进程阻塞,而影响自己。
开启子进程的第一种方法:
from multiprocessing import Process
import time,random
def piao (name):
print('%s is piaoing' %name)
# time.sleep(3000)
if __name__ == '__main__':
# p=Process(target=piao,args=('alex',))
p=Process(target=piao,kwargs={'name':'alex'})
p.start() #向操作系统发送开启子进程的信号
# p.join()
print ('主进程')
结果:
"D:\Program Files\Python36\python.exe" C:/Users/yangjianbo/PycharmProjects/untitled/第九课并发编程/开启子进程.py
主进程
alex is piaoing
结论:
p.start() 只是向操作系统发出一个开启子进程的信号,而不是真正的开启子进程。
当p.start()执行完以后,会立刻执行下一行代码,也就是print(),而不是等待子进程执行后,再执行print().
p.start()只能执行一次,多次会有报错。
上面的例子:如果我想要子进程执行完毕以后,再执行print(),如何实现?
子进程执行完,再执行主进程的代码。
from multiprocessing import Process
import time,random
def piao (name):
print('%s is piaoing' %name)
# time.sleep(3000)
if __name__ == '__main__':
# p=Process(target=piao,args=('alex',))
p=Process(target=piao,kwargs={'name':'alex'})
p.start() #向操作系统发送开启子进程的信号
p.join()
print ('主进程')
结果:
"D:\Program Files\Python36\python.exe" C:/Users/yangjianbo/PycharmProjects/untitled/第九课并发编程/开启子进程.py
alex is piaoing
主进程
结论:在p.start()后面添加一个p.join(),主进程就会在当前位置停下,等待子进程运行完成,再执行后面的代码。p.join()必须在p.start()的后面,否则子进程还未开启,p.join()也没有意义。这么做的意义就是为了防止主进程突然关闭,而导致子进程执行完毕以后,成为了僵尸进程。
开启子进程的第二种方法:
采用自定义类的方式。
from multiprocessing import Process
import time,random
class Myprocess(Process):
def __init__(self,name):
super(Myprocess,self).__init__()
self.name=name
def run(self):
print ('%s is piaoing' %self.name) if __name__ == '__main__':
p=Myprocess('alex')
p.start()
print('主')
套接字通信开启子进程
服务端:
from socket import socket
from multiprocessing import Process
def tongxin(conn,addr):
while True:
try:
cmd = conn.recv(1024) # 收消息,限制单个消息的最大数为1024字节
if not cmd: break
conn.send(cmd.upper())
except ConnectionResetError:
break
conn.close()
def lianjie():
s = socket()
s.bind(('127.0.0.1', 8080)) # 插卡,指定服务器的IP地址和端口号
s.listen(5)
while True:
conn, client_addr = s.accept()
p=Process(target=tongxin,args=(conn,client_addr))
p.start()
s.close() if __name__ == '__main__':
lianjie()
客户端:
import socket
client=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
client.connect(('127.0.0.1',8080)) #打电话 while True:
cmd=input('数据>>').strip()
if not cmd:continue
client.send(cmd.encode('utf-8')) #发消息
recv=client.recv(1024).decode('gbk') #收消息
print(recv) client.close()
进程对象的其他方法:
join方法:
from multiprocessing import Process
import time,random
def piao (name):
print('%s is piaoing' %name) if __name__ == '__main__':
p1=Process(target=piao,args=('alex',))
p2=Process(target=piao,args=('egon',))
p3 = Process(target=piao, args=('wupaiqi',))
p1.start()
p2.start()
p3.start() p1.join()
p2.join()
p3.join()
print ('主进程')
结果:
"D:\Program Files\Python36\python.exe" C:/Users/yangjianbo/PycharmProjects/untitled/第九课并发编程/进程的其他对象方法.py
egon is piaoing
alex is piaoing
wupaiqi is piaoing
主进程
结论:
三个start()都是随机开启的,不会按顺序启动的。
三个join要放在三个start的后面,这样才是并发。
from multiprocessing import Process
import time,random
def piao (name):
print('%s is piaoing' %name) if __name__ == '__main__':
p1=Process(target=piao,args=('alex',))
p2=Process(target=piao,args=('egon',))
p3 = Process(target=piao, args=('wupaiqi',))
p1.start()
p1.join()
p2.start()
p2.join()
p3.start()
p3.join()
# p1.join()
# p2.join()
# p3.join()
print ('主进程')
结果:
"D:\Program Files\Python36\python.exe" C:/Users/yangjianbo/PycharmProjects/untitled/第九课并发编程/进程的其他对象方法.py
alex is piaoing
egon is piaoing
wupaiqi is piaoing
主进程
结论:
如果是这么写的,就是真正的串行。
from multiprocessing import Process
import time,random
def piao (name):
print('%s is piaoing' %name) if __name__ == '__main__':
p1=Process(target=piao,args=('alex',))
p2=Process(target=piao,args=('egon',))
p3 = Process(target=piao, args=('wupaiqi',))
p_l=[p1,p2,p3]
for p in p_l:
p.start()
for p in p_l:
p.join()
print ('主进程')
进程之间的内存空间是隔离的
from multiprocessing import Process
n=100
def task():
global n
n=0
print (n)
if __name__ == '__main__':
p=Process(target=task)
p.start()
p.join()
print('主',n)
结果:
"D:\Program Files\Python36\python.exe" C:/Users/yangjianbo/PycharmProjects/untitled/第九课并发编程/进程之间的内存空间是隔离的.py
0
主 100
结论:
进程之间的内存空间是隔离的,因为我修改了子进程的n,但是主进程的n还是原来的。
查看进程的pid和ppid。
杀死进程
进程池
Python学习笔记九的更多相关文章
- python 学习笔记九 队列,异步IO
queue (队列) 队列是为线程安全使用的. 1.先入先出 import queue #测试定义类传入队列 class Foo(object): def __init__(self,n): self ...
- python学习笔记(九)、模块
1 模块 使用import 语句从外部导入模块信息,python提供了很大内置模块.当你导入模块时,你会发现其所在目录中,除源代码文件外,还新建了一个名为__pycache__的子目录(在较旧的Pyt ...
- python学习笔记九——序列
4.4 序列 序列是具有索引和切片能力的集合.元组.列表和字符串具有通过索引访问某个具体的值,或通过切片返回一段切片的能力,因此元组.列表和字符串都属于序列.序列索引功能演示: tuple=(&quo ...
- Python学习笔记九:装饰器,生成器,迭代器
装饰器 本质是函数,装饰其他函数,为其他函数添加附加功能 原则: 1不修改原函数的源代码 2不修改原函数的调用方式 知识储备: 1函数即变量 使用门牌号的例子说明函数,调用方式与变量一致 2高阶函数 ...
- Python学习笔记九-文件读写
1,读取文件: f=open('目录','读写模式',encoding='gbk,error='egiong') 后三项可以不写但是默认是' r'读模式:open函数打开的文件对象会自动加上read( ...
- Python学习笔记九:正则表达式
一:正则表达式的符号与方法 常用符号: .:匹配任何一个字符,换行符除外(所以,多行字符串中的匹配要特殊处理,见下面实例) *:匹配前一个字符0次或多次 +:匹配前一个字符1次或多次 ?:匹配前一个字 ...
- python学习笔记(九)函数返回多个值,列表生成式,循环多个变量,入参格式声明
一.函数返回多个值 1.函数如果返回多个值的话,它会把这几个值放到一个元组里面2.函数如果返回多个值的话,也可以用多个变量来接收 def say(): num1 = num2 = num3 = ret ...
- python学习笔记(九)-函数2
交换两个变量的值 a = 2 b = 1 b = 1 a = 2 #方式一: b,a = a,b #交换两个变量的值 print(a,b) #方式二: a = a + b #3 b = a - b # ...
- Python学习笔记(九)
Python学习笔记(九): 装饰器(函数) 内置函数 1. 装饰器 1. 作用域 2. 高阶函数 3. 闭包 如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就 ...
随机推荐
- 小数点保留n位有效数字
char *psf = "183.0000000000000001"; ]; sprintf(chBuff, "%.2lf", atof(psf)); doub ...
- element-ui和npm、webpack、vue-cli搭建Vue项目
一.element-ui的简单使用 1.安装 1. npm 安装 推荐使用 npm 的方式安装,它能更好地和 webpack 打包工具配合使用. npm i element-ui -S 2. CDN ...
- 获取本地的jvm信息,进行图形化展示
package test1; import java.lang.management.CompilationMXBean; import java.lang.management.GarbageCol ...
- dl,dt,dd标签的使用
dl就是定义一个列表 dt说明白了就是这个列表的标题dd就是内容,能缩进和UL,OL性质差不多 <dl> <dt>标题标题</dt> <dd>内容内容& ...
- python学习日记(OOP——@property)
在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9999 这显然不合逻辑.为了限制score的 ...
- Linux系统初始化配置项(centos7)
主机刚安装完系统,会做一些配置上的优化. 修改时区 通过命令将时区设置为亚洲/上海. timedatectl set-timezone Asia/Shanghai #centos7 cp /usr/s ...
- [bilibili]弹幕屏蔽列表
<filters> <item enabled="true">t=定单身</item> <item enabled="true& ...
- mysql ssh 跳板机(堡垒机???)连接服务器
跳板机(Jump Server),也称堡垒机,是一类可作为跳板批量操作远程设备的网络设备,是系统管理员或运维人员常用的操作平台之一. 正常的登录流程 使用ssh命令登录跳板机: 登录跳板机成功后,在跳 ...
- win32: 文本编辑框(Edit)控件响应事件
过去几年,关于文本编辑框(Edit)控件的响应事件,我都是在主程序 while(GetMessage(&messages, NULL, 0, 0)) { ... } 捕获. 总感觉这种方式让人 ...
- HDU2859 Phalanx (动态规划)
Today is army day, but the servicemen are busy with the phalanx for the celebration of the 60th anni ...