python自学博客记录 第12章 多线程与并行(3/2)

12.1 线程和进程介绍

12.1.1 进程基本概念
一个计算机系统进程包括下列数据:
1.进程对应的可执行机器码在存储器的映像。
2.分配到的存储器(通常是一个虚拟的存储器区域)。存储器的内容包括可执行代码、特定于进程的数据(输入、输出)、调用堆栈、堆栈(用于保存运行时运输中途产生的数据)
3.分配给该进程的资源的操作系统描述符、诸如文件描述符或文件句柄、数据源和数据终端。
4.安全特性,诸如进程拥有者和进程的权限集(可以容许的操作)。
5.处理器状态(内文),诸如寄存器内容、物理存储器地址等。当进程正在运行时,状态信息通常存储在寄存器,其他内容存储在存储器

12.1.2 线程基本概念
线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。
线程是独立调度和分派的基本单位,可以分为:
(1)操作系统内核调度的内核线程,如win32线程;
(2)由用户进程自行调度的用户线程
(3)由内核与用户进程进行混合调度,如windows 7 的线程

12.1.3 多线程的基本概念
多线程是指在软件或者硬件上实现多个线程并发执行的技术。
软件多线程:是说即便处理器只能运行一个线程,操作系统也可以快速地在不同线程之间进行切换,由于时间间隔很小,给用户造成一种多个线程在同时运行的假象。
12.1.4 Python与全局解释器锁
全局解释器锁(简称GIL)是计算机程序设计语言解释器用于同步线程的工具,保证任何时刻仅有一个线程在执行。
CPython的线程是操作系统的原生线程,完全由操作系统调度线程的执行,一个CPython解释器进程内有一个主线程以及多个用户多个用户程序的执行线程。即使使用多核心CPU平台,由于全局解释器锁的存在,也将禁止多线程的并行执行,这样会损失许多多线程的性能。

在CPython中,全局解释器锁是一个互斥锁,由于保护对Python对象的访问,防止多条线程同时执行Python字节码。这种锁是必要的,主要是因为CPython的内存管理不是线程安全的。
在多线程环境中,CPython虚拟机按以下方式执行:
1.设置全局解释器锁
2.切换到一个线程中去运行。
3.运行:
(1)指定数量的字节码指令;
(2)线程主动让出控制【可以调用time.sleep(0)】。
4.把线程设置为睡眠状态。
5.设置全局解释锁
6.再次重复以上所有步骤。
在调用外部代码的时候,全局解释器将会被锁定,直到最后一个函数结束为止(因为在这期间没有Python的字节码被运行,所有不会做线程切换)

12.2python线程模块

Python标准库中关于线程主要是 _thread和threading模块。
12.2.1 _thread模块
标准库中的_thread模块作为低级别的模块存在,一般不建议直接使用,但在某些简单的场合也是可以使用的,因为该模块的使用方法十分简单。
标准库_thread模块的核心就是start_new_thread方法
_thread.start_new_thread(function , args [ , kwargs])
启动一个新线程并返回其标识符,线程使用参数列表args(必须是元组)执行函数,可选的kwargs参数指定关键字参数的字典。当函数返回时,线程讲以静默方式退出。当函数以未处理的异常终止时,讲打印堆栈跟踪,然后线程退出(但其他线程继续运行)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值