潭州课堂25班:Ph201805201 并发(进程,线程) 第十一课 (课堂笔记)
线程,进程,是实现并发的方法,
并行:
在同一时刻,同时运行多个任务,CPU 的数量大于等于任务数量,
并发:
在同一时间间隔内, 同时处理多个任务,
并行是并发。
进程:表示一个正在执行的程序,
操作系统负责其上所有的执行
多进程
import multiprocessing
# from multiprocessing import process
import time # 模拟一个好使任务 print('a:',time.asctime(time.localtime(time.time()))) def func():
print('b:',time.asctime(time.localtime(time.time())))
time.sleep(5)
print('c:',time.asctime(time.localtime(time.time()))) # 进程实例 Process( target=func ,args=)
p = multiprocessing.Process( target=func )
p.start() # 启动 time.sleep(5)
print('d:',time.asctime(time.localtime(time.time())))
# 相当于两个 time.sleep(5) 同时运行

多个进程:
for i in range(30):
p = multiprocessing.Process( target=func )
p.start()
多进程并行的必要条件:
总进程数理不多于 CPU 核心数量
所以,现在运行的程序都是轮询调度产生的,
但在 python 层面的确获得了并行,
多线程实现并发:
线程,是执行的最小单元 ,多线程:是一个进程 中同时开户多个线程,线程可以被中断,也可以被挂起
GIL锁,在 python 里,一个进程一次只能有一个线程运行,
进程:进程当中最少有一个线程,是操作系统分配资源的基本单位,
线程:
# import multiprocessing # 进程
from threading import Thread # 线程对象
import time # 模拟一个好使任务 print('a:',time.asctime(time.localtime(time.time()))) def func():
print('b:',time.asctime(time.localtime(time.time())))
time.sleep(5)
print('c:',time.asctime(time.localtime(time.time()))) # 进程实例 Process( target=func ,args=) p = Thread( target=func )
p.start() # 启动 time.sleep(5)
print('d:',time.asctime(time.localtime(time.time())))
# 相当于两个 time.sleep(5) 同时运行

当线程遇到阻塞,睡眠,就会切换运行
在 linux 中
import os,time pid = os.fork() # 只要执行这个方法,就会COPY一个新的进程
if pid == 0:
print('子进程',pid) # 永远是 0
else:print('父进程 ',pid) # 返回的是子进程的 pid 值,
time.sleep(0.1)

因为两个进程都执行,同时两个成立,
多进程实现并发
# 多进程实现并发,
from socket import *
from multiprocessing import Process server = socket()
server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) # 重用端口
server.bind(('127.0.0.1', 10001))
server.listen(5) def fun(conn):
while True:
try:
r = conn.recv(1024)
if not r: break
conn.send(r)
except Exception:
break if __name__ == '__main__': # windows下
while True:
conn, addr = server.accept()
p = Process(target=fun, args=(conn,))
p.start()
多线程实现并发
# 多进程实现并发,
from socket import *
from threading import Thread server = socket()
server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) # 重用端口
server.bind(('127.0.0.1', 10001))
server.listen(5) def fun(conn):
while True:
try:
r = conn.recv(1024)
if not r: break
conn.send(r)
except Exception:
break if __name__ == '__main__': # windows下
while True:
conn, addr = server.accept()
p = Thread(target=fun, args=(conn,))
p.start()
潭州课堂25班:Ph201805201 并发(进程,线程) 第十一课 (课堂笔记)的更多相关文章
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第四课 登录注册 (课堂笔记)
index.html 首页 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第三课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第二课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 WEB 之 页面编写 第一课 (课堂笔记)
index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...
- 潭州课堂25班:Ph201805201 第十课 类的定义,属性和方法 (课堂笔记)
类的定义 共同属性,特征,方法者,可分为一类,并以名命之 class Abc: # class 定义类, 后面接类名 ( 规则 首字母大写 ) cls_name = '这个类的名字是Abc' # 在类 ...
- 潭州课堂25班:Ph201805201 并发(进程与线程池) 第十四课 (课堂笔记)
循环执行一个线程 # -*- coding: utf-8 -*- # 斌彬电脑 # @Time : 2018/7/20 0020 5:35 import threading import queue ...
- 潭州课堂25班:Ph201805201 并发(进程,线程)二 第十二课 (课堂笔记
线程与进程的其他相关操作 import threading # 线程 import multiprocessing # 进程 import socket import time def wo(): g ...
- 潭州课堂25班:Ph201805201 并发(协程) 第十五课 (课堂笔记)
#斐波那契 def fid(n): res = [] indx = 0 a = 0 b = 1 while indx < n : res.append(b) a,b = b,a+b indx + ...
- 潭州课堂25班:Ph201805201 并发(通信) 第十三课 (课堂笔记)
from multiprocessing import Process # 有个 url 列表 ,有5个 url ,一次请求是1秒,5个5秒 # 要求1秒把 url 请求完, a = [] # 在进程 ...
随机推荐
- JavaScript内置对象——Math对象
这几天在刷leetcode的时候用到了一些Math对象的知识,故作一下总结~ JavaScript中的Math对象也是一个常见的内置对象,然而与String等其它常见对象不同,Math对象没有构造函数 ...
- 升级版updateOozie.sh
以前的版本检测当天的Tar包,并只能选择1个Tar包进行更新代码,当天生成多个版本时需修改脚本中配置,并不方便. 升级版兼容目录下存在一个或者多个Tar包的情况: 1.单个Tar包时,直接解压缩到当前 ...
- visual studio 2017 installer 安装包制作过程出现的问题---此安装程序需要.NET Framework 版本 3.5,请安装该版本,然后重新运行此安装程序,可以从Web获得.NET Framework 。要立即做此事吗?
图一 visual studio 2017 installer 打包完成以后进行安装时,提示信息 “安装此安装程序需要.NET Framework 版本 3.5,请安装该版本,然后重新运行此安装程序, ...
- Java 企业级 JavaEE
授权协议:CDDL 开发语言:Java 操作系统:跨平台 开发厂商:Oracle 原文:https://www.oschina.net/p/j2ee Java EE 详细介绍 这是SUN公司推出的J2 ...
- LeetCode(52):N皇后 II
Hard! 题目描述: n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给定一个整数 n,返回 n 皇后不同的解决方 ...
- JVM内存管理概述
1.概述 java不在需要开发人员显示的分配内存和回收内存,而是由JVM自动管理内存的分配和回收(又称为垃圾回收-GC),这简化了编程难度,但同时可能使得程序员在不知不觉中浪费了很多内存,导致JVM花 ...
- laravel 接口跨域
最方便的方法,新建一个middleWare,把这个middleware加入到全局中间件,所有的请求,都会经过这个中间件的过滤. php artisan make:middleware CrossHtt ...
- STL整理之map
转载请注明出处,部分内容引自李煜东<算法竞赛进阶指南> 前置知识: C++.C语言入门 Map是什么 Map是从键(key)到值(value)的映射,其内部实现是一棵以key为关键码 ...
- hdu4052矩形面积并
建模需要注意下细节,,这是做扫描线的惯例,就是最好把模型建立在笛卡尔坐标系上 剩下的看链接和注释https://blog.csdn.net/shiqi_614/article/details/7983 ...
- 阿里巴巴 Java 开发手册评述
http://blog.jobbole.com/110427 阿里巴巴Java开发手册(终极版)https://pan.baidu.com/s/1c1UQM7Q 阿里巴巴Java开发规约插件p3cGi ...