-
sleep join yiled区别 sleep会让线程睡眠指定的时间,释放CPU时间片; join本质是wait/notify 本质是让线程的执行结果对被阻塞的线程可见 yiled 让出时间片,触发CPU的重新调度 -
Java中可以创建volatile数组吗 可以创建,但是volatile只是对引用可见,对数组中的元素,不是volatile的,可以通过代码进行验证,举例: 反汇编需要设置 JVM参数:-server -Xcomp -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly -XX:CompileCommand=compileonly,App. 详见使用JVM的HSDIS插件对java代码进行反汇编 反汇编之后,搜索lock指令,可以看到8行和12行代码对应的汇编指令中都加了lock指令, 而 11行代码,对volatile数组元素进行修改时,生成的汇编代码是没有lock指令的,也就是说volatile数组中的元素,volatile关键字是不能保证其可见性的。 volatile缓存行的填充——性能问题 让一个缓存填满整个缓存行是能提升效率的,如果两个缓存共用一个缓存行,当其中一个缓存失效时,另外一个数据的缓存也会被强制失效 -
Java中的++操作是否线程安全? 线程安全体现在三个方面: 原子性,有序性,可见性,而++操作,在底层是三个操作,无法满足原子性,是线程不安全的 -
线程什么时候抛出InterruptedException 当我们使用线程的interrupt()方法区中断一个处于阻塞状态(join sleep wait)的线程时,会抛出InterruptedException 追问:抛出InterruptedException时,应该怎么处理 -
Runnalbe Callable接口有什么区别 两者共同点是都是接口,区别前者不带返回值,后者是带返回值的 -
有三个线程t1,t2,t3 ,如何让它们顺序执行 可以通过join来实现 -
java 内存模型是什么 java内存模型是一种抽象模型,它定义了多线程程序对于共享内存数据的读写规范,体现在虚拟机中把共享变量存储到内存以及从内从中读取共享变量的底层细节实现,它解决的是CPU的多级缓存,处理器优化指令重排序导致的可见性问题 ,可以抽象成下图:
- 什么是线程安全
线程安全就是原子性,可见性,有序性;多个线程访问同一个共享变量时,对共享变量进行协调处理,以保证多个线程对共享变量的处理结果是正确的; 可见性:CPU高速缓存和指令的重排序导致线程的执行结果对其他线程的可见性 原子性:指单个指令或者多个指令不允许被中断执行;而实际情况是,指令是可以被中断执行,以及CPU时间片切换到其他指令执行 有序性:
threadLocal threadLocal 内存泄漏问题;为什么使用线性探测方法去查找 线性探测,向前查找,向后查找,替换掉key为null的Entry,以此方式解决重复的hashCode
|