Python3.5 学习九
进程与线程
线程(Thread)是计算机运算调度的最小单位,它存在于进程中,是实际运作单位。每个进程都可能并发多线程。
每一个程序的内存是独立的。
线程:是操作系统最小的运算调度单位,是一串指令的集合。
所有在同一进程里的线程是共享同一块内存空间,而多线程抢同一资源时会出现问题。
第一个创建的线程为主线程,但主线程和子线程之间没有任何隶属关系的,这与主进程子进程不一样
进程:一个程序执行的实例(应用程序)就被称为一个进程。要以一个整体形势暴露给操作系统来管理,里面包含对各种资源的调用,内存的对各种资源管理的结合,就可以成为进程。
进程和线程的区别:
1. 线程共享内存空间,进程的内存是独立的
2. 子线程共享内存空间,多子进程的资源都是相同的COPY,是独立而不是共享的。
3. 同一进程长得线程之间可以直接交流,两个进程之间如果要通信,必须通过一个中间代理来实现
4. 创建新线程很简单,创建新进程需要对其父进程进行一次克隆
5. 一个线程可以控制和操作同一进程里的其他线程,但进程只能操作子进程
6. 对主线程的修改有可能会影响其他线程的运行,但对父进程的修改,不会影响其他子进程的运行
7. 主线程关闭,不会影响其他子线程运行,主进程关闭,子进程也会结束。
线程类继承threading.Thread
等待线程结束:t.join()
将子线程设置为守护线程:t.setDaemon(True)
主线程退出,子线程便都退出了
全局解释器锁gil:多核的机器,可以真正同时并发
但是在C-Python中,实际只是一核在运算,调用操作系统的原生线程,只有同一时间可以拿到数据,实际以单核执行
Python将来使用pyty技术,会速度非常快。去掉全局解释器锁,加入了Justruntime,即时编译,边编译边执行,提前预编译一部分。
如果程序间需要锁套锁,需要使用递归锁的概念,Rlock
信号量:相当于房间的门,有多个,每个有一个锁,出来一个可以再进去一个
event=threading.event()
事件的方法:
set()
is_set()
clear()
wait()
红绿灯实例:
# Author:huhu
import threading
import time event = threading.Event()
def lighter():
count=0
event.set()
while True:
if count>=5 and count<10:#改成红灯
event.clear() #把标志位清空了
print("\033[41;1mred light is on...\033[0m")
elif count>10:
event.set()
count=0
else:
print("\033[42;1mgreen light is on...\033[0m")
time.sleep(1)
count+=1 def car(name):
while True:
if event.is_set():
print("[%s] is running..."%name)
time.sleep(1)
else:
print("[%s] sees red light...waiting..."% name)
event.wait()
print("\033[34;1m[%s] green light is on,start running.\033[0m"% name) light = threading.Thread(target=lighter,)
light.start() car1 = threading.Thread(target=car,args=("Tesla",))
car1.start() 重点知识之queue队列: 可理解为一个存放数据的容器,
class queue.Queue(maxsize=0) #先入先出
class queue.LifoQueue(maxsize=0) #后入先出
class queue.PriorityQueue(maxsize=0) #存储数据时可设置优先级的队列
重要的作用:
1 完成对程序解耦
2 提高运行效率
利用多线程和队列做一个生产者消费者多并发模型实例:详见20180810
本周作业:
开3个不同,主机用户名不同
简单主机批量管理:
主机列表
1 exec cmd
2 send file
每个操作是每台主机都做相同的操作
Python3.5 学习九的更多相关文章
- python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法
python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法 同一台机器同时安装 python2.7 和 python3.4不会冲突.安装在不同目录,然 ...
- python3.4学习笔记(九) Python GUI桌面应用开发工具选择
python3.4学习笔记(九) Python GUI桌面应用开发工具选择 Python GUI开发工具选择 - WEB开发者http://www.admin10000.com/document/96 ...
- python3.4学习笔记(四) 3.x和2.x的区别,持续更新
python3.4学习笔记(四) 3.x和2.x的区别 在2.x中:print html,3.x中必须改成:print(html) import urllib2ImportError: No modu ...
- python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容
python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容 Beautiful Soup 是用Python写的一个HTML/XML的解析器,它可以很好的处理不规范标记并生成剖 ...
- python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容
python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...
- python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...
- python3.4学习笔记(十八) pycharm 安装使用、注册码、显示行号和字体大小等常用设置
python3.4学习笔记(十八) pycharm 安装使用.注册码.显示行号和字体大小等常用设置Download JetBrains Python IDE :: PyCharmhttp://www. ...
- python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码
python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码 python的json.dumps方法默认会输出成这种格式"\u535a\u ...
- python3.4学习笔记(二十五) Python 调用mysql redis实例代码
python3.4学习笔记(二十五) Python 调用mysql redis实例代码 #coding: utf-8 __author__ = 'zdz8207' #python2.7 import ...
随机推荐
- CentOS 安装 Xamarin官方Mono
预先准备: 服务器可连入互联网 有yum 工具(没什么好说的,如果这个你没装,那重新装个系统吧,debian 等不要看这个,不一样的) wget 工具(可选) yum-uitl 工具包 导入Xamar ...
- VC字符串处理整理
场景: 1.在存储数据时有时接口需要合并字符串值,并以某些特殊字符来合并部分,到需要的时候再分割它.如一些数值,人名等. 2.C++有strtok,stringstream和find函数来实现分割.可 ...
- Scrum 团队成立 -- 软件工程
团队项目选题 : 金融工具:复利计算与投资记录项目继续升级,开发定位明确.功能专注的工具类软件 团队队员 : 蔡舜 , 林宇粲 , 王昕明 , 卢晓洵 团队目标 : 不断完善 团队口号 : 永不 ...
- Devexpress RichEditControl 导入word文件后字体变为方正姚体的解决方案
最近在做一个排版软件,用过RichEditControl 导入外部Word文件的时候,发现导的文件后字体会变成“方正姚体”,官方这个BUG至少在V16.1版本尚未解决,翻阅了大量资料,发现 DevEx ...
- maven使用感受
第一次接触的时候,什么都不懂,感觉好复杂. 后来系统地看了一个使用教程: 简单评价一下: 自动帮我们下载jar架包,还有就是可以执行命令自己部署到远程服务器上面去. 缺点: 学习成本.一般人不了解.第 ...
- seo工具
http://tool.seowhy.com/ 一.关键词查词类工具:可以查询出更多目标客户可能搜索的词语 1.百度指数:http://index.baidu.com/ 这个工具是使用人数最多的 2. ...
- [精彩] 关于DB2的内存分配
这两天在看DB2的内存管理的内容,看的很是模糊,有以下问题不明白,请教 是不是数据库管理器的共享内存就是DB2能够使用的最大内容呢,然后数据库全局内存从管理器内存那里获得分配的内存,然后应用程序全局内 ...
- PTA第一次作业和第二次作业
PTA的第一次作业第一题: #include <stdio.h> int main (void) { int grade,i,N ,a=0,b=0,c=0,d=0,e=0; printf( ...
- Activiti中23张表的含义
1.与流程定义相关的4张表: 2.与执行任务相关的5张表: 3.与流程变量相关的2张表
- 解决sea_born和matplotlib画图中文显示的问题
#以下解决mtpl中文显示问题 from pylab import * mpl.rcParams['font.sans-serif'] = ['SimHei'] #以下解决seaborn中文编码报错问 ...