进程与线程

线程(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 学习九的更多相关文章

  1. python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法

    python3.4学习笔记(十九) 同一台机器同时安装 python2.7 和 python3.4的解决方法 同一台机器同时安装 python2.7 和 python3.4不会冲突.安装在不同目录,然 ...

  2. python3.4学习笔记(九) Python GUI桌面应用开发工具选择

    python3.4学习笔记(九) Python GUI桌面应用开发工具选择 Python GUI开发工具选择 - WEB开发者http://www.admin10000.com/document/96 ...

  3. python3.4学习笔记(四) 3.x和2.x的区别,持续更新

    python3.4学习笔记(四) 3.x和2.x的区别 在2.x中:print html,3.x中必须改成:print(html) import urllib2ImportError: No modu ...

  4. python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容

    python3.4学习笔记(十七) 网络爬虫使用Beautifulsoup4抓取内容 Beautiful Soup 是用Python写的一个HTML/XML的解析器,它可以很好的处理不规范标记并生成剖 ...

  5. python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容

    python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...

  6. python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例

    python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...

  7. python3.4学习笔记(十八) pycharm 安装使用、注册码、显示行号和字体大小等常用设置

    python3.4学习笔记(十八) pycharm 安装使用.注册码.显示行号和字体大小等常用设置Download JetBrains Python IDE :: PyCharmhttp://www. ...

  8. python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码

    python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码 python的json.dumps方法默认会输出成这种格式"\u535a\u ...

  9. python3.4学习笔记(二十五) Python 调用mysql redis实例代码

    python3.4学习笔记(二十五) Python 调用mysql redis实例代码 #coding: utf-8 __author__ = 'zdz8207' #python2.7 import ...

随机推荐

  1. struts框架问题五之向值栈中保存数据

    5. 问题五: 向值栈保存数据 (主要针对root栈) > valueStack.push(Object obj); * push方法的底层调用root对象的push方法(把元素添加到0位置) ...

  2. 利用ks构建ISO中的一些坑

    构建ISO的基本流程 1.获取rpm包源码 2.将源码增量编译成二进制包 3.编写ks的包列表决定ISO制作时需要从什么地方(二进制仓库repo)取哪些二进制包 4.通过createiso命令并指定k ...

  3. TYVJ 1940 创世纪

    Description: 上帝手中有着 N 种被称作“世界元素”的东西,现在他要把它们中的一部分投放到一个新的空间中去以建造世界.每 种世界元素都可以限制另外一种世界元素,所以说上帝希望所有被投放的世 ...

  4. crontab误删除

    命令如下: cat /var/log/cron* | grep -i "`which cron`" > ./all_temp cat ./all_temp | grep -v ...

  5. JavaScript 代码小片段

    1.获取对象 obj 的所有属性(自有属性和继承属性),保存到数组 lst 中 //获取对象obj的所有属性(自有属性和继承属性),保存到数组lst 中 var lst = []; function ...

  6. 2018.07.20 bzoj3211: 花神游历各国(线段树)

    传送门 维护区间开方,区间求和.这个是线段树常规操作. 显然一个数被开方若干次之后要么是1,要么是0,所以用线段树维护区间最大和区间和,如果区间最大不超过1就剪枝剪掉,不然就继续递归直到叶节点时停下进 ...

  7. UVa 11280 Flying to Fredericton (DP + Dijkstra)

    题意:给出n(2<=n<=100)个城市之间的m(0<=m<=1000)条航线以及对应的机票价格,要求回答一些询问,每个询问是给出最大停留次数S,求从其实城市Calgary到终 ...

  8. (转)C#静态方法使用经验浅谈

    转自:http://developer.51cto.com/art/200908/147734.htm C#静态方法有什么弊端? 我们在实际的开发过程中会注意到C#静态方法对于我们程序的影响,那么有哪 ...

  9. (最小生成树)Constructing Roads -- poj -- 2421

    链接: http://poj.org/problem?id=2421 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 2113 ...

  10. android插件化简述

    2015年是Android插件化技术突飞猛进的一年,随着业务的发展各大厂商都碰到了Android Native平台的瓶颈: 从技术上讲,业务逻辑的复杂导致代码量急剧膨胀,各大厂商陆续出到65535方法 ...