——————————————————————————————————
进程
- 进程是指在操作系统中能独立运行并作为资源分配的基本单位,由一组机器指令、数据和堆栈等组成的能独立运行的活动实体。
- 进程在运行是需要一定的资源,如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一直在打空转
- 需要同时运行多个线程
写多少个线程比较合适?
一般是二十四十个线程比较合适(回答的时候答2040之间的具体一个数),一方面因为CPU有上下文切换,消耗时间;另一方面读写数据库单批次数据不能太大,太大会影响数据库的性能
线程优先级
下面代码,设置5个高优先级,5个低优先级,让10个线程处于就绪态,一起竞争资源,谁的count越大,谁竞争到的次数越多(优先级高的,竞争到的次数应该高)
但是结果是,高优先级和低优先级count结果一样,说明设置的优先级没用
public class Priority {
private static volatile boolean notStart = true;//为true,在29行的循环才能执行
private static volatile boolean notEnd = true;