多线程编程第一讲

什么是进程?

进程 是指在系统中正在运行的一个应用程序,每个进程之间都是独立的,每个进程均在其专用且受保护的内存空间内。

什么是线程?

进程要想执行任务,必须得有线程(每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)共享进程资源

在同一进程找中的各个线程,都可以共享该进程所拥有的资源,这首先表现在:所有线程都具有相同的地址空间(进程的地址空间),这意味着。线程可以访问该地址空间的每一个虚地址;此外,还可以访问进程所拥有的已打开文件、定时器。信号量机构等。由于同一进程内的线程共享内存和文件,所以线程之间互相通信不必调用内核。 

线程的状态

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

波雅_汉库克

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值