Python学习笔记__10章 进程和线程

# 这是学习廖雪峰老师python教程的学习笔记

1、概览

现代操作系统比如Mac OS X,UNIX,Linux,Windows等,都是支持“多任务”的操作系统。

而多任务,就是指操作系统可以同时运行多个任务。多任务的实现靠的是任务交替执行(时间片)

 

多任务的实现有3种方式:

  • 多进程模式;

  • 多线程模式;

  • 多进程+多线程模式。

 

线程是最小的执行单元,而进程由至少一个线程组成。如何调度进程和线程,完全由操作系统决定,程序自己不能决定什么时候执行,执行多长时间。

2、进程和线程的基本概念

2.1、进程(process)

1)狭义定义

进程就是一段程序的执行过程。

2)广义定义

进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动。它是操作系统动态执行的基本单元,在传统的操作系统中,进程既是基本的分配单元,也是基本的执行单元。

3)进程的两点主要概念

1)进程是一个实体。每一个进程都有它自己的地址空间,一般情况下,包括文本区域(text region)、数据区域(data region)和堆栈(stack region)。

  • 文本区域存储处理器执行的代码;

  • 数据区域存储变量和进程执行期间使用的动态分配的内存;

  • 堆栈区域存储着活动过程调用的指令和本地变量

2)进程是一个“执行中的程序”。程序是一个没有生命的实体,只有处理器赋予程序生命时,它才能成为一个活动的实体,我们称其为进程。

4)进程状态的三个状态

就绪、运行和阻塞。

  • 就绪状态其实就是获取了出cpu外的所有资源,只要处理器分配资源就可以马上执行。就绪状态有排队序列什么的,排队原则不再赘述。

  • 运行态就是获得了处理器分配的资源,程序开始执行。

  • 阻塞态,当程序条件不够时候,需要等待条件满足时候才能执行,如等待i/o操作时候,此刻的状态就叫阻塞态。

2.2、程序

程序是指令和数据的有序集合,其本身没有任何运行的含义,是一个静态的概念。而进程则是在处理机上的一次执行过程,它是一个动态的概念。进程其实是包含程序的,进程的执行离不开程序,进程中的文本区域就是代码区,也就是程序。

2.3、线程

通常在一个进程中可以包含若干个线程,当然一个进程中至少有一个线程,不然没有存在的意义。线程可以利用进程所拥有的资源,在引入线程的操作系统中,通常都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位,由于线程比进程更小,基本上不拥有系统资源,故对它的调度所付出的开销就会小得多,能更高效的提高系统多个程序间并发执行的程度。

2.4、多线程

在一个程序中,这些独立运行的程序片段叫作“线程”(Thread),利用它编程的概念就叫作“多线程处理”。多线程是为了同步完成多项任务,不是为了提高运行效率,而是为了提高资源使用效率来提高系统的效率。线程是在同一时间需要完成多项任务的时候实现的。

 

最简单的比喻多线程就像火车的每一节车厢,而进程则是火车。车厢离开火车是无法跑动的,同理火车也不可能只有一节车厢。多线程的出现就是为了提高效率。

 

3、进程和线程的区别

进程和线程的主要差别在于它们是不同的操作系统资源管理方式

3.1、地址空间

  • 进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响

  • 线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮

3.2、切换效率

  • 进程的切换涉及到程序上下文的切换,地址空间的切换,耗费资源较大

  • 线程共享地址空间,相对进程切换就要快一些

3.3、进程与线程的联系

1) 简而言之,一个程序至少有一个进程,一个进程至少有一个线程.

 

2) 线程的划分尺度小于进程,使得多线程程序的并发性高。

 

3) 进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率

 

4) 线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

 

5) 从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。

3.4、进程与线程的优缺点

  • 线程执行开销小,但不利于资源的管理和保护;而进程正相反

  • 线程适合于在SMP(多核处理机)机器上运行,而进程则可以跨机器迁移

 

4、原文档

进程、线程、多线程相关总结 (https://www.cnblogs.com/fuchongjundream/p/3829508.html)

5、参考文档

线程和进程的区别是什么? (https://www.zhihu.com/question/25532384)

进程和线程 (https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014319272686365ec7ceaeca33428c914edf8f70cca383000)



猜你喜欢

转载自blog.51cto.com/12758568/2116992
今日推荐