Java——》进程 VS 线程

推荐链接:
    总结——》【Java】
    总结——》【Mysql】
    总结——》【Redis】
    总结——》【Kafka】
    总结——》【Spring】
    总结——》【SpringBoot】
    总结——》【MyBatis、MyBatis-Plus】
    总结——》【Linux】
    总结——》【MongoDB】
    总结——》【Elasticsearch】

1. 进程与线程

进程的本质是一个正在执行的程序,程序运行时系统会创建一个进程,并且给每个进程分配独立的内存地址空间保证每个进程地址不会相互干扰。同时,在 CPU 对进程做时间片的切换时,保证进程切换过程中仍然要从进程切换之前运行的位置出开始执行。所以进程通常还会包括程序计数器、堆栈指针。

进程:在操作系统中,正在运行的一个应用程序(操作系统给这个程序分配内存资源)

线程:一个进程的最基本的执行单位(执行路径),也是CPU调度的基本单位

区别进程线程
根本不同操作系统分配的资源CPU调度的基本单位
资源不同进程之间的资源通常是独立
同一个进程下的线程共享进程中的一些资源
线程同时拥有自身的独立存储空间
数量不同一个进程线程是依附于某个进程的
一个进程中至少会有一个或多个线程
开销不同进程之间的通讯很麻烦,一般要借助内核才可以实现线程的创建和终止的时间是比较短的,而且线程之间的切换比进程之间的切换速度要快很多,线程之间通讯,相当方便

2. 多进程与多线程

多进程:在操作系统中,同时运行的多个应用程序,每个程序分配独立的内存地址空间

多线程在同一个进程中,同时执行多个线程(多条执行路径)

2.1 多进程

2.1.1 优点

充分利用CPU,提高CPU的使用率。

2.2 多线程

2.2.1 优点

提高进程的执行使用率,提高CPU的使用率。

2.2.2 缺点

  1. 消耗资源问题:线程数量特别多,CPU在切换线程上下文时,会额外造成很大的消耗
  2. 线程安全问题:虽然多线程带来了一定的性能提升,但是再做一些操作时,多线程如果操作临界资源,可能会发生一些数据不一致的安全问题,甚至涉及到锁操作时,会造成死锁问题。

2.2.3 使用场景

多线程可以通过避免一些网络IO或者磁盘IO等需要等待的操作,让CPU去调度其他线程。

3. 总结

  1. 在同一个时间点一个CPU中只可能有一个线程在执行
  2. 多线程不能提高效率、反而会降低效率,但是可以提高CPU的使用率
  3. 一个进程如果有多条执行路径,则称为多线程程序
  4. Java虚拟机的启动至少开启了两条线程,主线程和垃圾回收线程
  5. 一个线程可以理解为进程的子任务

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值