进程与线程的区别和联系

1.什么是线程

一个线程就是一个 "执行流",每个线程之间都可以按照顺讯执行自己的代码,多个线程之间 "同时" 执行 着多份代码。

之前说进程相当于一个任务,我们可以举一个例子来描述一下进程和线程之间的关系,我们将一个工厂称为一个进程,工厂中有很多条流水线,每条流水线都在生产一个汽车不同部位的零件,将这些流水线上的零件组合起来就能形成一辆汽车。这时候,我们可以称每一条流水线为一个线程,整个工厂为一个进程。

上面的这种情况我们就称为多线程,将一个大的任务分解为多个小任务,然后分配给不同的执行流去完成。

2.为什么要有线程

还是拿生产汽车零件的例子来说,现在有很多个工厂,每个工厂只有一条流水线,生产汽车不同部位的零件,最后将这些工厂生产出来的零件也能组装成一辆汽车,既然这样也可以,那线程的存在意义上什么呢?

1."并发编程"成为"刚需"

  • 单核CPU的发展已经遇到了瓶颈,要进一步提高算力,就需要多核CPU,并发编程能更充分的利用多核CPU的资源
  • 某些场景需要"等待IO",为了让等待的时间可以去做一些其他的事情,也需要用到并发编程

2.虽然多进程也能实现并发编程,但是线程比进程更轻量

  • 创建线程比创建进程更快
  • 销毁线程比销毁进程更快
  • 调度线程比调度进程更快

3.进程和线程的区别

  • 进程包含线程,每个进程至少有一个线程,即主线程
  • 进程和进程之间不共享内存空间,同一个进程的线程之间共享同一个内存空间
  • 进程是系统分配资源的最小单位,线程是系统调度的最小单位 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
进程是操作系统进行资源分配的基本单位,而线程是进程内的一个执行单元,也是进程内的可调度实体。一个进程可以包含多个线程,而线程共享了进程的某些资源。进程线程之间存在以下区别: 1. 本质区别进程是操作系统进行资源分配的基本单位,而线程是独立调度和分派的基本单位。 2. 包含关系:一个进程内可以有多个线程,线程是进程的一部分,因此线程也被称为轻量级进程或轻权进程。 3. 资源开销:每个进程都有独立的代码和数据空间,程序之间的切换会有较大的开销;而线程可以看作轻量级的进程,同一类线程共享代码和数据空间,线程之间切换的开销小。 4. 创建和销毁:创建一个进程需要遍历内存资源找到合适的内存再分配给它,销毁进程也需要遍历内存资源。而创建和销毁一个线程相对不那么麻烦。 5. 内存分配:同一个进程线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的。 6. 影响关系:一个进程崩溃后,在保护模式下不会对其他进程产生影响;但一个线程崩溃可能会导致包含该线程的整个进程直接死掉。 7. 操纵者不同:进程的操纵者一般是操作系统,线程的操纵者一般是编程人员。 8. 执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口,而线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值