进程和线程的区别和联系

1、进程、线程的基本概念

在计算机中,所有的应用程序都是由CPU执行的,对于一个CPU而言,在某个时间点只能运行一个程序,也就是说只能执行一个进程。操作系统会为每一个进得分配―盼有限的CPU使用时间,CPU在这段时间中执行某个进程,然后会在下一段时间切换到另一个讲程中去执行。由于CPU运行速度非常快,能在极短的时间内在不同的进程之间进行切换,所以给人以同时执行多个程序的感觉。

1.1 、进程

1.1.1、进程的定义

进程(Process) 是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。 在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。

1.1.2、进程的特征

  • 动态性:进程是程序的一次执行过程,它随着程序的执行而创建,经历不同的状态变化,直到最终消亡。
  • 并发性:指多个进程可以在同一时间段内执行,它们轮流占用处理器以实现并发执行的效果。
  • 独立性:进程是一个能独立运行、独立获得资源和独立接受调度的基本单位。
  • 异步性:进程的执行速度和顺序是不确定的,它们以不可预知的速度向前推进。
  • 结构性:进程由程序段、数据段和进程控制块(PCB)组成,PCB描述了进程的基本信息和状态。

1,1,3、进程的基本状态及状态之间的装换

进程执行时的间断性决定了进程可能具有多种状态。事实上,运行中的进程可能具有以下三种基本状态。

(1)就绪(Ready)状态

当进程已分配到除CPU以外的所有必要资源后,只要再获得CPU,便可立即执行,进程这时的状态称为就绪状态。在一个系统中处于就绪状态的进程可能有多个,通常将它们排成一个队列,称为就绪队列。

(2) 执行状态

进程已获得CPU,其程序正在执行。在单处理机系统中,只有一个进程处于执行状态;在多处理机系统中,则有多个进程处于执行状态。

(3) 阻塞状态

正在执行的进程由于发生某事件而暂时无法继续执行时,便放弃处理机而处于暂停状态,亦即进程的执行受到阻塞,把这种暂停状态称为阻塞状态,有时也称为等待状态或封锁状态。致使进程阻塞的典型事件有:请求I/O,申请缓冲空间等。通常将这种处于阻塞状态的进程也排成一个队列。有的系统则根据阻塞原因的不同而把处于阻塞状态的进程排成多个队列。处于就绪状态的进程,在调度程序为之分配了处理机之后,该进程便可执行,相应地,它就由就绪状态转变为执行状态。正在执行的进程也称为当前进程,如果因分配给它的时间片已完而被暂停执行时,该进程便由执行状态又回复到就绪状态;如果因发生某事件而使进程的执行受阻(例如,进程请求访问某临界资源,而该资源正被其它进程访问时),使之无法继续执行,该进程将由执行状态转变为阻塞状态。图2-5示出了进程的三种基本状态以及各状态之间的转换关系。

                             

关系:

将阻塞态的进程挂起,变成挂起阻塞态,当导致进程阻塞的I/O操作在用户重启进程前完成(称之为唤醒),挂起阻塞态变成挂起就绪态,当用户在I/O操作结束之前重启进程,挂起阻塞态变成阻塞态;将就绪(或运行)中的进程挂起,变成挂起就绪态,当该进程恢复之后,挂起就绪态变成就绪态;

1.2、线程

1.2.1、线程的定义

线程(thread) 是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。

1.2.2、线程的特征

  • 并发性/并行性:线程可以在同一时间内处理多个任务,但在单核处理器中,这通常意味着任务会轮换执行,实现逻辑上的同时进行。在多核处理器中,多个任务可以真正地同时执行。
  • 共享资源:同一进程中的多条线程共享该进程中的全部系统资源,如虚拟地址空间、文件描述符和信号处理等。
  • 独立性: 每个线程有自己的调用栈、寄存器环境和线程本地存储。
  • 优先级: 线程执行时具有一定的优先级,优先级高的线程获得更多的执行机会。
  • 轻量级: 相比于进程,线程占用更少的资源,创建和销毁线程的开销也较小。
  • 原子性:线程的最小执行单元不可被分割,这是线程操作的最小不可中断单位。
  • 可见性:当一个线程修改了共享变量的值,其他线程应能立即感知到这个变化。
  • 有序性:线程中的操作应按照指令的顺序依次执行,但这也可能因优化和CPU的乱序执行而被打乱。
  • 同步与调度:线程可以通过用户态的线程库管理,也可以在操作系统层面进行调度和管理。

      在多核或多CPU的计算机上,使用多线程技术可以提高程序的执行效率和吞吐率。在单核单CPU的计算机上,多线程技术也可以将负责I/O处理、人机交互等常被阻塞的部分与密集计算的部分分开执行,从而提高程序的执行效率。

2、进程与线程的关系

1.进程是资源分配的基本单位,线程是CPU调度和分派的基本单位

2.线程是进程的一部分,一个线程只能属于一个进程,一个进程可以有多个线程,但至少有一个线程

3.每个进程都有独立的代码和数据空间(程序上下文),程序间的切换开销大,线程可看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数(PC),线程间切换开销小

4.在操作系统中能同时运行多个进程(程序)在同一个进程(程序)中多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)

5.系统在运行的时候会为每个进程分配不同的内存空间线程除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源

6.没有现成的进程可以看做单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,维斯多条线(线程)共同完成。线程是进程的一部分,故线程被称为轻权进程/轻量级进程

3、进程和线程的区别

1. 根本区别:进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位

2. 资源开销:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。

3. 包含关系:如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

4. 内存分配:同一进程的线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的

5. 影响关系:一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮。

6. 执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口。但是线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制,两者均可并发执行

4、结语

进程和线程是操作系统中的重要概念,它们在程序执行和资源管理中起着不可替代的作用。了解它们的区别和联系有助于我们更好地理解程序的运行机制提高程序的性能和可靠性。在实际编程中,选择合适的进程和线程模型可以更好地满足程序的需求提高程序的效率和响应速度。

  • 32
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Starry灬

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

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

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

打赏作者

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

抵扣说明:

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

余额充值