线程和进程的区别及Python代码实例


Posted in Python onFebruary 04, 2015

在程序猿的世界中,线程和进程是一个很重要的概念,很多人经常弄不清线程和进程到底是什么,有什么区别,本文试图来解释一下线程和进程。首先来看一下概念:

进程(英语:process),是计算机中已运行程序的实体。进程为曾经是分时系统的基本运作单位。在面向进程设计的系统(如早期的UNIX,Linux 2.4及更早的版本)中,进程是程序的基本执行实体;在面向线程设计的系统(如当代多数操作系统、Linux 2.6及更新的版本)中,进程本身不是基本运行单位,而是线程的容器。程序本身只是指令、数据及其组织形式的描述,进程才是程序(那些指令和数据)的真正运行实例。?维基百科

线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。?维基百科

概念太吓人了,先来看一下进程,这个相对于线程来说还是稍微好理解一点的。进程,是程序运行的实体,这句话的意思是,程序是存放在硬盘中的,当这个程序运行时,就会产生若干个进程,并且这个进程是可见的,在windows8的任务管理器中,我们看到有下列进程:

线程和进程的区别及Python代码实例

那么什么是线程呢?如果你编写过程序,特别是类似windows的批处理这样的逻辑控制语句少的语言,就能明显感觉到,当运行一个程序是,实际上整个运行的过程是从头部一直运行到尾部。例如有这样一段批处理的代码,提示用户输入姓名,然后根据姓名输出问候:

@echo off
set /p name=请输入您的姓名: 
cls
echo 你好,%name
pause

这段小程序就是自上而下执行,执行完毕则退出。不管是批处理,像PHP,Node.JS等都是这样自上而下执行的。实际上这就是一个线程,可以这样去理解:线程是一个任务流,它被包含在进程之中。有个例子:

5月1号这一天,麦当劳生意比较火爆,人很多,前台有6个窗口,有4个窗口在工作,随着要吃饭的人变多,麦当劳不得不开放了剩余的两个窗口。在这里,每一个窗口就是一个进程,处理卖垃圾食品这样一个任务,让系统需要处理更多请求时候,开放窗口就是增加进程来处理需求。由于是假期,发现即使是6个窗口全开了,排队的客户还是很多,那么,这里是不是没有其它的办法了呢?效率都是逼出来的,经理发现,客户买完东西,在旁边等,当客户的汉堡(或者其它垃圾食品)准备好了,是由单独的一个人(小明)把食品递给客户,由于这个人需要把准备好的食物分别送给6个不同窗口的客户,所以效率很低。这时候经理发话了,食品准备好了,直接由窗口的售卖人员把食品给正在等在的客户,这样比较节省时间。在这里,前台售卖人员的工作就有原来的一项专门售卖商品的工作,变成了两项,就是两个进程。

进上总结,一个进程中至少有一个线程,在实际的工作中,不是所有的程序都支持多线程,也有一些程序对多进程也支持得不够好,像PHP,Node.js等都是单进程,单线程的。

下面这个python的脚本让一个进程中运行两个线程:

import time 
import thread 
def Ordering(interval): 
  cnt = 0 
  while cnt<100: 
    print '好了,你订餐成功,订餐号码是:%d号 订餐时间是:%s 请在旁边耐心等待\n\n'%(cnt, time.ctime()) 
    time.sleep(interval) 
    cnt+=1 
  thread.exit_thread() 
def Notice(interval): 
  cnt = 0 
  while cnt<100: 
    print '谁的号码是%d,您的餐好了,过来取一下\n'%(cnt) 
    time.sleep(interval) 
    cnt+=1 
  thread.exit_thread()  
  
def work(): #Use thread.start_new_thread() to create 2 new threads 
  thread.start_new_thread(Ordering,(1,)) 
  thread.start_new_thread(Notice,(5,)) 
  
if __name__=='__main__': 
  work()
Python 相关文章推荐
Python模块包中__init__.py文件功能分析
Jun 14 Python
Python决策树分类算法学习
Dec 22 Python
Python实现的栈(Stack)
Jan 26 Python
python创造虚拟环境方法总结
Mar 04 Python
python批量修改文件夹及其子文件夹下的文件内容
Mar 15 Python
python中将两组数据放在一起按照某一固定顺序shuffle的实例
Jul 15 Python
python 函数的缺省参数使用注意事项分析
Sep 17 Python
pytorch实现查看当前学习率
Jun 24 Python
使用anaconda安装pytorch的实现步骤
Sep 03 Python
如何通过Python实现RabbitMQ延迟队列
Nov 28 Python
利用python爬取有道词典的方法
Dec 08 Python
python 30行代码实现蚂蚁森林自动偷能量
Feb 08 Python
Python中使用PIPE操作Linux管道
Feb 04 #Python
Python实现在Linux系统下更改当前进程运行用户
Feb 04 #Python
使用Python编写Linux系统守护进程实例
Feb 03 #Python
Python中使用select模块实现非阻塞的IO
Feb 03 #Python
Python异常学习笔记
Feb 03 #Python
Python中的迭代器漫谈
Feb 03 #Python
Python描述器descriptor详解
Feb 03 #Python
You might like
上海无线电三厂简史修改版
2021/03/01 无线电
PHP 将逗号、空格、回车分隔的字符串转换为数组的函数
2012/06/07 PHP
PHP 验证码不显示只有一个小红叉的解决方法
2013/09/30 PHP
PHP实现的redis主从数据库状态检测功能示例
2017/07/20 PHP
JavaScript 设计模式 安全沙箱模式
2010/09/24 Javascript
JS实现程序暂停与继续功能代码解读
2013/10/10 Javascript
jQuery实现等比例缩放大图片让大图片自适应页面布局
2013/10/16 Javascript
jQuery中size()方法用法实例
2014/12/27 Javascript
Angular用来控制元素的展示与否的原生指令介绍
2015/01/07 Javascript
4种JavaScript实现简单tab选项卡切换的方法
2016/01/06 Javascript
JS生成某个范围的随机数【四种情况详解】
2016/04/20 Javascript
jquery按回车键实现表单提交的简单实例
2016/05/25 Javascript
jQuery Easyui使用(二)之可折叠面板动态加载无效果的解决方法
2016/08/17 Javascript
jQuery树形插件jquery.simpleTree.js用法分析
2016/09/05 Javascript
Python给你的头像加上圣诞帽
2018/01/04 Python
python多线程共享变量的使用和效率方法
2019/07/16 Python
Python3常用内置方法代码实例
2019/11/18 Python
Python面向对象编程基础实例分析
2020/01/17 Python
利用Python的folium包绘制城市道路图的实现示例
2020/08/24 Python
如何使用pycharm连接Databricks的步骤详解
2020/09/23 Python
HTML5 与 XHTML2
2008/10/17 HTML / CSS
使用spring mvc+localResizeIMG实现HTML5端图片压缩上传的功能
2016/12/16 HTML / CSS
Html5中localStorage存储JSON数据并读取JSON数据的实现方法
2017/02/13 HTML / CSS
法国亚马逊官方网站:Amazon.fr
2020/12/19 全球购物
12岁生日感言
2014/01/21 职场文书
《孔子拜师》教学反思
2014/02/24 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
房屋出租协议书
2014/04/10 职场文书
关于十八大的演讲稿
2014/09/15 职场文书
2014年党员发展工作总结
2014/12/02 职场文书
房产公证书
2015/01/23 职场文书
小王子读书笔记
2015/06/29 职场文书
2019年大学生职业生涯规划书
2019/03/25 职场文书
Python实现8种常用抽样方法
2021/06/27 Python
7个关于Python的经典基础案例
2021/11/07 Python
nginx 配置缓存
2022/05/11 Servers