面试内容索引
多线程JUC
1、 forkJoin分支合并框架
2、 Stream并行流分支合并技术更优解决方案
3、 CompletableFuture异步回调
-
CompletableFuture 和 Future 都是 Java 中的异步编程的重要工具,但是有一些重要的区别:
- Future 只是一个单纯的异步任务,而 CompletableFuture 则是一个可以完成的异步任务。
- CompletableFuture 允许你注册回调函数,以便在异步任务完成后进行操作。 Future 则不允许。
- CompletableFuture 可以轻松地与其他 CompletableFuture 进行组合,以便在多个异步任务完成后执行操作。 Future 则不能。
- CompletableFuture 支持流式编程,以便在异步任务完成后自动进行后续操作。 Future 则不能。
总体而言,CompletableFuture 是 Future 的升级版,提供了更强大的功能,以更方便地进行异步编程。
4、进程线程区别
![在这里插入图片描述](https://img-blog.csdnimg.cn/ca4be54c585e49e6af8f88eab01e165a.png
5、查看进程线程的方法
6、多线程运行原理
7、上下文切换
8、多线程常用方法(run、sleep、yield、join、interrupt)
9、多线程两阶段终止线程
10、守护线程
11、多线程的状态
12、synchronized
- 黑马juc简单介绍
- synchronized和volatile都具有可见性,其中synchronized对一个类或对象加锁时,一个线程如果要访问该类或对象必须先获得它的锁,而这个锁的状态对于其它任何线程都是可见的,并且在释放锁之前会将对变量的修改刷新到主存当中,保证资源变量的可见性,如果某个线程占用了该锁,其他线程就必须在锁池中等待锁的释放。
- 而volatile的实现类似,被volatile修饰的变量,每当值需要修改时都会立即更新主存,主存是共享的,所有线程可见,所以确保了其他线程读取到的变量永远是最新值,保证可见性
- synchronized可以保证原子性,而volatile不可以保证原子性 volatile不能保持原子性的举例
- synchronized可见性测试后得出结论,多线程修改引用地址,修改后试不可见的,修改堆里的内容是可见,比如修改boolean不可见,修改list.set(0) 就可见
- synchronized支持可重入性
- synchronized是非公平锁
13、线程8锁例子,用来实践synchronized锁锁住的哪些对象
14、对象头 markword 和klassword
15、synchronizid原理之monitor
- Owner:当前获取到锁的线程ID
- EntryList:Dlocked线程所在的队列
- WaitSet:
- monitor 是重量级锁的原理,是由操作系统提供的操作,比较慢
黑马juc
16、synchronizid原理之字节码角度(monitorenter、monitorexit)
- monitorenter将lock对象 MarkWord 置为 Monitor指针
- monitorexit 将对象 MarkWord 重置,唤醒EntryList
黑马juc