1 Java 多线程、JVM、集合,Java 常用数据结构
1.1 多线程
1.1.1 进程与线程
进程是程序的一次动态执行过程,它需要经历从代码加载,代码执行到执行完毕的一个完整的过程,这个过程也是进程本身从产生,发展到最终消亡的过程。
多线程是指一个进程在执行过程中可以产生多个更小的程序单元,这些更小的单元称为线程,这些线程可以同时存在,同时运行,一个进程可能包含多个同时执行的线程。
1.1.2 线程实现的方式
实现 Runnable 接口 允许调用多个接口
继承 Thread 类 不支持多重继承
1.1.3 线程的状态
任何线程一般具有5种状态,即
创建:线程被创建,但是未启动(未调用start())
就绪:线程被启动(调用start()),处于可执行状态,等待CPU的调度;
运行:线程正常的运行状态;
阻塞:
等待阻塞:运行的线程执行wait()方法,jvm会把该线程放入waitSet线程池(释放锁);
同步阻塞(死锁):运行的线程在获取其他对象的同步锁是,该对象的同步锁被别的线程锁占用,则jvm会将该线程放入线程池中;
其他阻塞:运行的线程执行sleep方法或者执行t.join()方法,被别的线程打断,jvm把该线程置为阻塞状态,当sleep超时或者join线程结束时线程重新进入就绪状态
终止:一个线程正常执行结束;
Java 程序每次运行至少启动几个线程?
回答:至少启动两个线程,每当使用 Java 命令执行一个类时,实际上都会启动一个 JVM,每一个JVM实际上就是在操作系统中启动一个线程,Java 本身具备了垃圾的收集机制。所以在 Java 运行时至少会启动两个线程,一个是 main 线程,另外一个是垃圾收集线程。
1.1.4 线程的操作
强制: join() 线程强制运行指的是当满足某些于某些条件之后,某一个线程对象可以一直独占资源,一直到该线程的程序执行结束。
休眠:sleep() 休眠可以使一个线程暂缓处理,休眠时间一到程序就会唤醒继续执行
中断:interrupt() 线程中断指的是别人可以打断自己某个线程的休眠,所有正在执行的线程都是被中断的,中断线程必须进行异常的处理。
后台:setDaemon 指程序在运行时后台提供的一种通用服务线程,并且这种线程并不属于程序中不可或缺的一部分。
优先级:从理论上来讲,线程的优先级越高越有可能先执行(越有可能先抢占资源)。
礼让:yield