多线程原理

本文详细介绍了Java多线程的原理,包括线程状态、正确的线程中止方式、内存屏障与CPU缓存、线程通信以及线程封闭。讲解了线程的六种状态,强调了interrupt方法在停止线程中的正确使用,讨论了CPU缓存的一致性协议和内存屏障的作用。此外,还探讨了线程间的通信方式,如wait/notify机制和park/unpark,并提到了ThreadLocal在实现线程封闭中的应用。
摘要由CSDN通过智能技术生成

多线程原理

1.线程状态

6个状态定义:java.lang.Thread.State

  1. New:尚未启动的线程的线程状态;
  2. Runnable:可运行线程的线程状态.等待CPU调度;
  3. Blocked:线程阻塞等待监视器锁定的线程状态.处于synchronized同步代码块中或方法中被阻塞;
  4. Waiting:等待线程的线程状态.下列不带超时的方式:Object.wait,Thread.join,LockSupport.park;
  5. Timed Waiting:具有指定等待时间的等待线程的线程状态.下列带超时的方式:Thread.sleep,Object.wait,Thread.join,LockSupport.parkNanos,LockSupport.parkUntil;
  6. Terminated:终止线程的线程状态.线程正常完成执行或者出现异常;

image-20200910110802257

2.线程中止

2.1.不正确的线程中止-stop

stop:中止线程,并且清除监控器锁的信息,但是可能导致线程安全问题,JDK不建议使用;

estory:JDK未实现该方法;

2.2.正确的线程中止-interrupt

如果目标线程在调用Object class的wait(),wait(long)或wait(long,int)方法,join(),join(long,int)方法时被阻塞,那么interrupt会生效,该线程的中断状态将被清除,抛出InterrptedException异常;

如果目标线程是被I/O或者NIO中的Channel所阻塞,同样,I/O操作会被终端或者返回特殊异常值.达到终止线程的目的;

如果以上条件都不满足,则会设置此线程的中断状态;

2.3.正确的线程中止-标志位

代码逻辑中,增加一个判断,用来控制线程执行的中止;

image-20200913104753033

3.内存屏障和CPU缓存

3.1.CPU性能优化手段-缓存

为了提高程序运行的性能,现代CPU在很多方面对程序进行了优化;

例如:CPU高速缓存,尽可能地避免处理器访问主内存的时间开销,处理器大多会利用缓存(cache)以提高性能.

image-20200913105308400

多级缓存

  • L1 Cache(一级缓存)是CPU第一层高速缓存,分为数据缓存和指令缓存.一般服务器的CPU的L1缓存容量通常在32-4096kb.
  • L2 由于L1级高速缓存容量的限制,为了再次提高CPU的运算速度,在CPU外部放置一高速存储器,即二级缓存.
  • L3 现在的都是内置的,而它的实际作用即是,L3缓存的应用可以进一步降低内存延迟,同时提升大数据量计算时处理器的性能.具有较大L3缓存的处理器提供更有效的文件系统缓存行为及较短消息和处理器队列长度.一般是多核共享一个L3缓存.

CPU在读取数据时,现从L1中寻找,再从L2寻找,再从L3寻找,然后是内存,再后是外存储器.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值