自己实战整理面试题--多线程(带答案,不断更新)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/w372426096/article/details/83754513

一个线程两次调用 start() 方法会出现什么情况?线程的生命周期,状态是如何转移的?

Java 的线程是不允许启动两次的,第二次调用必然会抛出 IllegalThreadStateException,这是一种运行时异常,多次调用 start 被认为是编程错误。

关于线程生命周期的不同状态,在 Java 5 以后,线程状态被明确定义在其公共内部枚举类型 java.lang.Thread.State 中,分别是:

新建(NEW),表示线程被创建出来还没真正启动的状态,可以认为它是个 Java 内部状态。

就绪(RUNNABLE),表示该线程已经在 JVM 中执行,当然由于执行需要计算资源,它可能是正在运行,也可能还在等待系统分配给它 CPU 片段,在就绪队列里面排队。

在其他一些分析中,会额外区分一种状态 RUNNING,但是从 Java API 的角度,并不能表示出来。

阻塞(BLOCKED),这个状态和我们前面两讲介绍的同步非常相关,阻塞表示线程在等待 Monitor lock。比如,线程试图通过 synchronized 去获取某个锁,但是其他线程已经独占了,那么当前线程就会处于阻塞状态。

等待(WAITING),表示正在等待其他线程采取某些操作。一个常见的场景是类似生产者消费者模式,发现任务条件尚未满足,就让当前消费者线程等待(wait),另外的生产者线程去准备任务数据,然后通过类似 notify 等动作,通知消费线程可以继续工作了。Thread.join() 也会令线程进入等待状态。

计时等待(TIMED_WAIT),其进入条件和等待状态类似,但是调用的是存在超时条件的方法,比如 wait 或 join 等方法的指定超时版本,如下面示例:

public final native void wait(long timeout) throws InterruptedException;
终止(TERMINATED),不管是意外退出还是正常执行结束,线程已经完成使命,终止运行,也有人把这个状态叫作死亡。
在第二次调用 start() 方法的时候,线程可能处于终止或者其他(非 NEW)状态,但是不论如何,都是不可以再次启动的。


线程的阻塞的方式
wait,sleep分别是谁的方法,区别?
JDK 中有哪几个线程池?顺带把线程池讲了个遍
多线程的常用方法和接口类及线程池的机制
进程和线程的区别?
进程之间如何保证同步?
如何保证线程安全问题?

Synchronized关键字原理?

volatile 原理?volatile的用途
volatile 的原子性问题?为什么 i++支持原子性?从计算机原理的设计来讲下不能保证原子性的原因
happens before 原理
进程的状态转化(进程的三种状态间的基本转换)。
(Java后端技术公众号)
线程和进程的概念、并行和并发的概念
创建线程的方式及实现
进程间通信的方式
说说 CountDownLatch、CyclicBarrier 原理和区别
说说 Semaphore 原理
说说 Exchanger 原理
countLatch的await方法是否安全,怎么改造

说说线程安全问题,什么实现线程安全,如何实现线程安全;
创建线程池有哪几个核心参数? 如何合理配置线程池的大小?

ThreadLocal原理,注意事项,参数传递
ThreadLocal的使用场景和原理;

ThreadLocal 原理分析,ThreadLocal为什么会出现OOM,出现的深层次原理
ThreadLocal什么时候会出现OOM的情况?为什么?

threadlocal使用时注意的问题(ThreadLocal和Synchonized都用于解决多线程并发访问。但是ThreadLocal与synchronized有本质的区别。synchronized是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问。而ThreadLocal为每一个线程都提供了变量的副本,使得每个线程在某一时间访问到的并不是同一个对象,这样就隔离了多个线程对数据的数据共享。而Synchronized却正好相反,它用于在多个线程间通信时能够获得数据共享)

java线程池

线程池参数,整个流程描述

线程池的原理,为什么要创建线程池?创建线程池的方式,线程池的几种实现方式
什么时候会出现僵死进程?
可参考:《Java多线程编程核心技术》
为什么线程执行要调用start而不是直接run(直接run,跟普通方法没什么区别,先调start,run才会作为一个线程方法运行)
java的concurrent包用过没,Java 并发包原理?

aqs,cas?
原子类,线程安全的对象,异常的处理方式
可重入锁中对应的wait和notify
java线程池中基于缓存和基于定长的两种线程池,当请求太多时分别是如何处理的?定长的事用的队列,如果队列也满了呢?交换进磁盘?基于缓存的线程池解决方法呢?



 

猜你喜欢

转载自blog.csdn.net/w372426096/article/details/83754513