java高级内容_Java高级程序员必备的内容知识

一段时间没有回顾多线程相关知识了,虽然工作中会用到一些多线程的内容,但都偏向于基础,今天java培训带大家重读多线程相关内容,发现有些东西还是需要注意下。这些一般是面试高频问题奥。

了解并发的内幕是一个高级程序员不可缺少的课程

Java内存模型

注意,Java内存模型(JMM)和JVM运行时数据区不是同一个概念,还有一个概念是Java对象模型下次可以单独拿出来说。

JMM都是围绕着原子性,可见性,有序性来讲的

JMM定义了JVM如何与计算机的内存进行交互

线程对变量的所有操作都需要在工作内存中完成,不可直接操作主内存。

08834c9c2358c3c26cd42a1c67ee0510.png

内存间的交互操作:

Lock,Unlock主内存

Read,Write主内存

Load,Store工作内存的变量

Use,Assign工作内存的变量

Volatile

Volatile可以说是Java虚拟机内提供的最轻量级同步机制,其只保证,可见性与有序性,不保证原子性。

可见性:当一条线程修改了这个变量的值,新值对于其他线程来说是可以立刻得知的,另外两个可以实现可见性的关键字:Synchronized和final

有序性:如果再本线程内观察,所有的操作都是有序的,如果再一个线程中观察另外一个线程,那么所有的操作都是无序的。

Java与线程

并发不一定依赖多线程,如PHP中常见的多进程并发。Java的Thread类所有关键方法都是声明为Native的,所以Java并没有自己实现线程。

实现线程的三种方式:使用内核线程实现,使用用户线程实现,和使用用户线程加更加轻量级进程实现。

内核线程实现(KLT,Kernel-Level Thread)。程序一般不会直接使用内核线程,而是使用内核线程的一种高级接口,轻量级进程(LWP,Light Weight Process,LWP),先有内核线程,才能有轻量级进程。

缺点:各种线程操作,如创建,析构,及同步需要进行系统调用,而系统调用的代价比较高,需要在用户态和内核态中来回切换。消耗内核资源,一个系统支持轻量级的进程数量是有限制的。

用户线程实现,广义上说,一个线程只要不是内核线程,那就可以任务是用户线程。用户线程完全在用户态完成,不用内核的帮助,可以支持更大的线程数量。

缺点:没有内核支持,各种操作都比较复杂。现在基本弃用了。

用户线程+轻量级进程,综合两者的有点,用户进程与轻量级进程数量比是不定的。

线程调度

协同式调度:好处是实现简单,切换操作对线程自己是可知的,没有线程同步的问题,线程把自己的事情干完之后才进行线程切换。

缺点:如果程序编写不稳定,那么系统不可控制。一个进程坚持不让出CPU执行实现,就会导致系统崩溃。

抢占式调度(Java默认调度):每个线程由系统来分配执行和弦,线程的切换不由线程来决定,当一个进程出现问题,系统可以杀掉这个进程。

注意:并不是线程的优先级越高,线程就一定会优先执行,只是说优先级高的线程更可能被选择到。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值