什么是进程?
进程 是指在系统中正在运行的一个应用程序,每个进程之间都是独立的,每个进程均在其专用且受保护的内存空间内。
什么是线程?
进程要想执行任务,必须得有线程(每1个进程至少要有1条线程(主线程)),线程是进程的基本执行单元,一个进程(程序)的所有任务都在线程中执行。
进程是由若干个线程组成的,一个进程至少有一个线程。
线程的特点:
1)线程内核对象
操作系统对线程和线程的管理都是通过相应的内核对象实现的。它会为每个线程都分配并初始化这种数据结构。在该数据结构中,包含一组对线程进行描述的属性。数据结构中还包含所谓的线程上下文。上下文是一个内存块。其中包含了CPU的寄存器集合。
2)线程控制块
线程的实体包括程序。数据和线程控制块TCB(ThreadControl Block)。线程是动态概念,TCB包括以下信息:
(1)线程状态。
(2)当线程不运行时,被保护的现场资源。
(3)一组执行堆栈。
(4)存放每个线程的聚币变量主存区。
(5)访问同一个进程中的主存和其他资源。
3)独立调度和分派的基本单位
线程是能独立运行的基本单位,因而也是独立调度和分派的基本单位。CPU是以线程为单位执行,创建出来的线程不一定马上执行,调度后允许线程运行一个“时间片”,单核处理器一个时间片只允许执行一个线程,而多核处理器可以允许一个进程中所有线程都能并发执行。
4)上下文切换
线程是由CPU进行调度的,CPU的一个时间片内只执行一个线程上下文内的线程,当CPU由执行线程A切换到执行线程B的过程中会发生一些列的操作,如“保存线程A的执行现场“然后”载入线程B的执行现场”,这个过程称之为“上下文切换(context switch)”,这个上下文切换过程会消耗资源,应该尽量减少上下文切换的发生。
引起上下文切换的原因
1.时间片用完了,CPU正常调度下一个任务
2.被其他优先级更高的任务抢占
3.执行任务碰到IO阻塞,调度器挂起当前任务,切换任务执行下一个任务
4.用户代码主动挂起当前任务让出CPU时间
5.多任务抢占资源,由于没有抢到被挂起
6.硬件中断
5)共享进程资源
在同一进程找中的各个线程,都可以共享该进程所拥有的资源,这首先表现在:所有线程都具有相同的地址空间(进程的地址空间),这意味着。线程可以访问该地址空间的每一个虚地址;此外,还可以访问进程所拥有的已打开文件、定时器。信号量机构等。由于同一进程内的线程共享内存和文件,所以线程之间互相通信不必调用内核。
线程的状态