线程,进程,是实现并发的方法,

并行:

  在同一时刻,同时运行多个任务,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 并发(进程,线程) 第十一课 (课堂笔记)的更多相关文章

  1. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第四课 登录注册 (课堂笔记)

    index.html 首页 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  2. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第三课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  3. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第二课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  4. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第一课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  5. 潭州课堂25班:Ph201805201 第十课 类的定义,属性和方法 (课堂笔记)

    类的定义 共同属性,特征,方法者,可分为一类,并以名命之 class Abc: # class 定义类, 后面接类名 ( 规则 首字母大写 ) cls_name = '这个类的名字是Abc' # 在类 ...

  6. 潭州课堂25班:Ph201805201 并发(进程与线程池) 第十四课 (课堂笔记)

    循环执行一个线程 # -*- coding: utf-8 -*- # 斌彬电脑 # @Time : 2018/7/20 0020 5:35 import threading import queue ...

  7. 潭州课堂25班:Ph201805201 并发(进程,线程)二 第十二课 (课堂笔记

    线程与进程的其他相关操作 import threading # 线程 import multiprocessing # 进程 import socket import time def wo(): g ...

  8. 潭州课堂25班:Ph201805201 并发(协程) 第十五课 (课堂笔记)

    #斐波那契 def fid(n): res = [] indx = 0 a = 0 b = 1 while indx < n : res.append(b) a,b = b,a+b indx + ...

  9. 潭州课堂25班:Ph201805201 并发(通信) 第十三课 (课堂笔记)

    from multiprocessing import Process # 有个 url 列表 ,有5个 url ,一次请求是1秒,5个5秒 # 要求1秒把 url 请求完, a = [] # 在进程 ...

随机推荐

  1. How to scroll down with Phantomjs to load dynamic content

    page.open('http://example.com/?q=houston', function () { // Checks for bottom div and scrolls down f ...

  2. mysql系列十二、mysql常用hint

    对于经常使用oracle的朋友可能知道,oracle的hint功能种类很多,对于优化sql语句提供了很多方法.同样,在mysql里,也有类似的hint功能.下面介绍一些常用的. 强制索引 FORCE ...

  3. GBDT、XGBOOST、LightGBM调参数

    总的认识: LightGBM  > XGBOOST  > GBDT 都是调参数比较麻烦. GBDT分类的最佳调参数的讲解: Gradient Boosting Machine(GBM)调参 ...

  4. PYTHON-模块 logging hashlib

    '''import logging # 1. 控制日志级别# 2. 控制日志格式# 3. 控制输出的目标为文件logging.basicConfig(filename='access.log', fo ...

  5. SpringMVC(2):Spring MVC入门

    原文出处: 张开涛 2.1.Spring Web MVC是什么 spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思 ...

  6. (String中)正则表达式使用如下

    package zhengze;/* * 正则表达式 */public class StringTestZhengZe { public static void main(String[] args) ...

  7. poj 1321 棋盘问题(n行中放任意k行)

    n*n的棋盘摆K的棋子,任意两个棋子不能在同一行同一列 Sample Input 2 1#.  //# 可放.#4 4...#..#..#..#...-1 -1Sample Output 21 # i ...

  8. System.getenv()和System.getProperty() 的区别

    1.System.getenv() 方法是获取指定的环境变量的值.它有两种方法,一种是接收参数为任意字符串,当存在指定环境变量时即返回环境变量的值,否则返回null.另外一种是不接受参数,那么返回的是 ...

  9. Map集合遍历的四种方式理解和简单使用

    ~Map集合是键值对形式存储值的,所以遍历Map集合无非就是获取键和值,根据实际需求,进行获取键和值 1:无非就是通过map.keySet()获取到值,然后根据键获取到值 for(String s:m ...

  10. AngularJS+Node.js+socket.io 开发在线聊天室

    所有文章搬运自我的个人主页:sheilasun.me 不得不说,上手AngularJS比我想象得难多了,把官网提供的PhoneCat例子看完,又跑到慕课网把大漠穷秋的AngularJS实战系列看了一遍 ...