Java并发编程—进程、线程、协程、纤程、管程

——————————————————————————————————

进程

  • 进程是指在操作系统中能独立运行并作为资源分配的基本单位,由一组机器指令、数据和堆栈等组成的能独立运行的活动实体。
  • 进程在运行是需要一定的资源,如CPU、存储空间和I/O设备等。
  • 进程是资源分配的基本单位,进程的调度涉及到的内容比较多(存储空间,CPU,I/O资源等,进程现场保护),调度开销较大,在并发的切换过程效率较低。
  • 为了更高效的进行调度,提出了比进程更轻量的独立运行和调度的基本单位。

进程间通信方式

  • 进程间通信是一组编程接口,让程序员能够协调不同的进程,使之能在一个操作系统里同时运行,并相互传递、交换信息。
  • 这使得一个程序能够在同一时间里处理许多用户的要求。
  • 因为即使只有一个用户发出要求,也可能导致一个操作系统中多个进程的运行,进程之间必须互相通话。
  • —>IPC接口就提供了这种可能性。
  • 每个IPC方法均有它自己的优点和局限性,一般,对于单个程序而言使用所有的IPC方法是不常见的。
    进程间通信的8种方法:
    1)无名管道通信
    2)高级管道通信
    3)有名管道通信
    4)消息队列通信
    5)信号量通信
    6)信号
    7)共享内存通信
    8)套接字通信
    注:
  • 线程有的通信方式进程不一定有
  • 进程有的通信方式线程一定有
  • 因为进程是由线程组成的

线程

  • 进程是由线程组成的;线程本质是一个栈
  • 线程能独立运行,独立调度,拥有资源(一般是CPU资源,程序计数器等);
  • 线程调度能大幅度减小调度的成本(相对于进程来说);
  • 线程的切换不会引起进程的切换;
  • 线程的引入进一步提高了操作系统的并发性,线程能并发执行 同一个进程的多个线程共享进程的资源(省去了资源调度现场保护的很多工作)。

什么时候需要使用多线程?

  • 在cpu产生浪费时,需要性能提升的时候 cpu什么时候产生浪费比较严重?
    • 网络IO、磁盘IO的时候浪费比较严重
    • 网络IO:网络请求数据,在数据回来之前cpu一直在打空转
    • 磁盘IO:向磁盘发出调度,等数据回来也是cpu一直在打空转
  1. 需要同时运行多个线程

写多少个线程比较合适?

一般是二十四十个线程比较合适(回答的时候答2040之间的具体一个数),一方面因为CPU有上下文切换,消耗时间;另一方面读写数据库单批次数据不能太大,太大会影响数据库的性能

线程优先级

下面代码,设置5个高优先级,5个低优先级,让10个线程处于就绪态,一起竞争资源,谁的count越大,谁竞争到的次数越多(优先级高的,竞争到的次数应该高)
但是结果是,高优先级和低优先级count结果一样,说明设置的优先级没用

public class Priority {
   
    private static volatile boolean notStart = true;//为true,在29行的循环才能执行
    private static volatile boolean notEnd = true;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值