《Python核心编程》 18.多线程编程(一)

一进程和线程

1参考链接:

http://www.zhihu.com/question/25532384OF小工zhonyong 的回答

总结他们两的回答:

引言:

1.电脑的运行,在硬件上是CPU、相关寄存器、RAM之间的事情。负责处理任务的顺序有CPU决定。

2.程序的上下文:当CPU处理任务时,所需要的各种资源(显卡、寄存器等)准备完毕,构成了这个程序的执行环境,即上下文。

3.CPU处理任务顺序:先加载程序A的上下文,然后开始执行A,保存程序A的上下文,调入下一个要执行的程序B的程序上下文,然后开始执行B,保存程序B的上下文。

总结:

进程:包换上下文切换的程序执行时间总和 = CPU加载上下文+CPU执行+CPU保存上下文

线程:CPU执行程序时所划分的各个‘迷你进程’,共享上下文环境。

2本书描述

进程(重量级进程):是程序的一次执行。

每个进程都有自己的地址空间、内存、数据栈及其他记录其运行轨迹的辅助数据。操作系统管理(这里应该是是指CPU)在其上运行的所有进程,并为这些进程公平的分配时间。

各个进程都有自己的内存空间、数据栈等,所以只能使用进程间通讯(iterprocess communication,IPC),而不能直接共享信息。

线程(轻量级进程):类似于进程,不同的是,所有的线程运行在同一个进程中,共享相同的运行环境(同一片数据空间)。故这种并行和数据共享机制是多任务合作变为可能。

线程分为开始、顺序执行和结束三部分。有自己的指令指针,记录自己运行到什么地方。

线程的运行可能被抢占(中断),或暂时挂起(也叫作睡眠),让其他的线程运行,这叫做让步。

在单CPU系统中,不可能真正并行运行多线程。每个线程被安排成每次只运行一小会,然后把CPU让出来,让其他线程去运行。

在进程的整个运行过程中,每个线程都只做自己的事,在需要的时候跟其他的线程共享运行的结果。

二 Python、全局解锁器器(GIL)

在Python中,代码由Python虚拟机(也叫解释器主循环)来控制。

Python解释器中,可以存放多个线程,但任意时刻,只有一个线程在运行。

Python解释器由全局解释器锁(global interpreter lock,GIL)来控制。在多线程环境中,Python解释器按以下方式执行:

1.设置GIL

2.切换到一个线程中去运行

3.运行:

a.指定数量的字节码的指令,或

b.线程主动让出控制(调用time.sleep(n))

4.把线程设置为睡眠状态。

5.解锁GIL。

6.重复以上步骤。

三Python中关于线程模块的介绍

thread模块:提供了基本的线程和锁的支持。(OF小工的回答中有关于锁的形象介绍)

threading模块:提供了更高级别、功能更强的的线程管理功能。

Queue(队列)模块:运行用户创建一个可以用于多个线程之间共享数据的队列数据结构。

三不推荐使用thread模块原因

1.thread模块中的属性可能会与threading出现冲突。

2.thread模块的同步原语(关于线程的函数?)很少。

3.对进程结束时间没有控制(要使用锁)。

4.不支持守护线程

时间: 2024-11-05 20:34:15

《Python核心编程》 18.多线程编程(一)的相关文章

18 多线程编程 - 《Python 核心编程》

?? 引言/动机 ?? 线程和进程 ?? 线程和 Python ?? thread 模块 ?? threading 模块 ?? 生产者-消费者问题和 Queue 模块 ?? 相关模块 18.1 引言/动机 18.2 线程和进程 什么是进程? 计算机程序只不过是磁盘中可执行的,二进制(或其它类型)的数据.它们只有在被读取到内 存中,被操作系统调用的时候才开始它们的生命期.进程(有时被称为重量级进程)是程序的一次 执行.每个进程都有自己的地址空间,内存,数据栈以及其它记录其运行轨迹的辅助数据.操作系

廖雪峰Java13网络编程-1Socket编程-3TCP多线程编程

TCP多线程编程 一个ServerSocket可以和多个客户端同时建立连接,所以一个Server可以同时与多个客户端建立好的Socket进行双向通信. 因此服务器端,当我们打开一个Socket以后,通常使用一个无限for循环,在这个for循环内部,每次调用accept方法,返回一个与远程客户新建的Socket连接,紧接着启动一个新的线程,来处理这个连接. ServerSocket ss = new ServerSocket(port); for( ; ; ){ Socket sock = ss.

《Python核心编程》18.多线程编程(三)

18.6使用threading模块 #!/usr/bin/env python # -*- coding:utf-8 -*- """从Thread类中派生出一个子例,创建一个这个子类的实例""" import threading from time import sleep, ctime loops = (4, 2) class MyThread(threading.Thread): """ 1.子类化Thread类

《Python核心编程》18.多线程编程(二)

18.1没有线程支持 #!/usr/bin/env python # -*- coding:utf-8 -*- from time import sleep, ctime def loop0(): print 'start loop 0 at:', ctime() sleep(4) print 'loop 0 done at', ctime() def loop1(): print 'start loop 1 at:', ctime() sleep(2) print 'loop 1 done a

python核心编程(多线程编程)

1.全局解释器锁 2.threading模块 thread类 原文地址:https://www.cnblogs.com/goobai/p/8689060.html

python并发编程之多线程编程

一.threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 二.开启线程的两种方式 方式一: from threading import Thread import time import random def task(name): print('%s is running' %name) time.sleep(random.randint(1,3)) print('%s is end' %name)

《Python核心编程》 第3版 中文版pdf

下载地址:网盘下载 内容简介 编辑 Python是一种功能十分强大的面向对象编程语言,可以用于编写独立程序.快速脚本和复杂应用的原型.作为一种开源软件,Python可以自由获取,而且非常易学易用.本书是Python语言的经典入门读本,由两名顶尖的Python技术专家兼培训专家联手撰写,涵盖了该语言的所有核心内容.所有练习的解答都可在书后找到. 本书描述了Python程序的基本构件:类型.操作符.语句.函数.模块.类以及异常和介绍了更多高级主题,包括复杂的实例.无论是用于编写简单的脚本,还是复杂的

Python核心编程 第3版 中文版pdf

[下载地址] <Python核心编程(第3版)>是经典畅销图书<Python核心编程(第二版)>的全新升级版本,总共分为3部分.第1部分为讲解了Python的一些通用应用,包括正则表达式.网络编程.Internet客户端编程.多线程编程.GUI编程.数据库编程.Microsoft Office编程.扩展Python等内容.第2部分讲解了与Web开发相关的主题,包括Web客户端和服务器.CGI和WSGI相关的Web编程.Django Web框架.云计算.高级Web服务.第3部分则为一

python核心编程第二版

初学Python这是一本有关Python开发的指南涵盖近期发布的Pyttlon版本的核心功能特性,而不仅仅是语法学习更多的高阶内容,如正则表达式.网络.多线程.图形用户界面.Web/CGl和Python扩展等包括几个全新的章节,关于数据库.网络客户端.Java/Jytt30n和Microsoft Office等 展示数以百计的代码片段.交互实例和大量加强您的Python技能的实用练习"对Wesley Chun<Python核心编程>第二版的漫长等待是值得的--它的深邃.它的全面,以及