进程和线程

1 进程和线程的区别
1.1 进程
  • 进程是程序执行时的一个实例。进程是系统进行资源分配的基本单位,。

  • 每个进程拥有独立的地址空间(代码段、堆栈段和数据段、只读数据段)。一个进程无法直接访问另一个进程的变量和数据结构, 如果希望让一个进程访问另一个进程的资源,需要使用进程间通信(进程间的通信)。

  • 进程之间的切换会有较大的开销。

  • 在多线程 OS 中,进程不是一个可执行的实体,即一个进程至少创建一个线程去执行代码

  • 一个服务器通常需要接收大量并发请求,为每一个请求都创建一个进程系统开销大、请求响应效率低,因此操作系统引进线程。

1.2 线程
  • 线程是操作系统进行资源调度的最小单位。

  • 一个进程可以拥有多个线程,线程是进程的一个实体,是进程的一条执行路径

  • 同一类线程共享进程代码段、数据段和堆(全局变量、静态变量、new创建的对象等),每个线程有独立的运行栈和程序计数器(PC)。

    • PC寄存器用来存储指向下一条指令的地址,也即将要执行的指令代码。
      任何时间一个线程都只有一个方法在执行,也就是所谓的当前方法。程序计数器会存储当前线程正在执行的java方法的JVM指令地址,如果是在执行native方法,则是未指定值(undefined)。
      JVM第四篇 程序计数器(PC寄存器)
    • 栈存储该线程的局部变量、操作数栈、返回地址、动态连接等信息。
      jvm栈帧包含哪些内容
      在这里插入图片描述
  • 线程上下文切换比进程上下文切换快,代价小。

  • 线程可以通过共享数据段进行通信,比较方便。

在这里插入图片描述

2 各自的适用场景
2.1 优先使用线程
  • 需要频繁创建销毁的优先使用线程。因为进程创建、销毁一个进程代价很大,需要不停的分配资源。
  • 线程的切换速度快,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应。
  • 并行性要求很高时,如C/S架构的服务器端并发线程响应用户的请求。
  • 多机分布的用进程,多核分布用线程。
2.2 优先使用进程
  • 需要跨机器移植时。
  • 需要更稳定、更安全时。

【参考文档】
什么时候用进程?什么时候用线程?
什么是线程?什么是进程?为什么要有线程?有什么关系与区别?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值