当前位置: 首页 > news >正文

北京营销型网站建设培训优化大师使用心得

北京营销型网站建设培训,优化大师使用心得,h5个人网页制作,江阴网站建设实例方法: interrupt()方法是设置结束阻塞(sleep、),并且设置中断标记true isInterrupted()判断当前是否中断 静态方法: Thread.interrupted():调用这个方法的线程中断标记位还原为false 那么好,既然上面的方法作用是清晰的&…

实例方法:

interrupt()方法是设置结束阻塞(sleep、),并且设置中断标记true

isInterrupted()判断当前是否中断

静态方法:

Thread.interrupted():调用这个方法的线程中断标记位还原为false

那么好,既然上面的方法作用是清晰的,尝试启动个线程进行操作:

一.疑惑1,为什么如下代码调用后会出现false

@Slf4j
public class InterruptTest {public static void main(String[] args) {Thread t1 = new Thread(() -> {try {Thread.currentThread().sleep(5000);} catch (InterruptedException e) {log.info("中断状态1:{}", Thread.currentThread().isInterrupted());}});t1.start();try {Thread.sleep(2000); // 等待2秒,确保主线程调用t1线程interrupt时t1是启动好的} catch (InterruptedException e) {e.printStackTrace();}t1.interrupt();}
}
输出结果:  InterruptTest - 中断状态1:false

不是说线程实例方法interrupt()调用后会设置中断标记嘛,为什么是false

解答:InterruptedException 被抛出时,JVM 会自动清除当前线程的中断标志

它清除中断标志是为了避免开发者不小心忽略异常后,线程还带着一个“脏标志”继续运行,导致逻辑混乱,真是贴心的很。

一.疑惑2,既然JVM自动清理标记,再调用interrupt()总可以看到true了吧

public static void main(String[] args) {Thread t1 = new Thread(() -> {try {Thread.currentThread().sleep(5000);} catch (InterruptedException e) {log.info("中断状态1:{}", Thread.currentThread().isInterrupted());Thread.currentThread().interrupt();log.info("中断状态2:{}", Thread.currentThread().isInterrupted());Thread.interrupted();log.info("中断状态3:{}", Thread.currentThread().isInterrupted());}});t1.start();try {Thread.sleep(2000); // 等待2秒,确保主线程调用t1线程interrupt时t1是启动好的} catch (InterruptedException e) {e.printStackTrace();}t1.interrupt();}

运行结果:果然出现了true

thread.InterruptTest2 - 中断状态1:false
thread.InterruptTest2 - 中断状态2:true
thread.InterruptTest2 - 中断状态3:false

thread.cpp下的interrupt函数:(807行是调用操作系统的逻辑)

继续跟进到os_linux.cpp,也可以分系统选看,我直接选Linux的了

如果线程不是阻塞状态(例如未在 sleep()、park() 或 wait() 等阻塞点),这段代码的效果仅仅是改了中断标志位,其他操作(如 unpark() 唤醒线程)不会有实际作用,也不会耽误线程继续运行。

thread.cpp的is_interrupted函数:

 同样溯源到os_linux.cpp

一.疑惑3,wait、notify-all为什么都要加同一个synchronized

阅读Object相关源码:objectMonitor.cpp

wait函数:

尾插法放入队列: 

_WaitSetLock 是一个自旋锁,用于保护 WaitSet 的并发访问,在objectMonitor.hpp中

也就是WAIT/TIME WAIT本质上是用一个Object中的等待队列去存储需要等待的线程对象,每一个Object对象都可以充当这个角色,获取这个对象的waitset才能把Thread放入,唤醒相当于再从这个waitset中把线程剔除来再唤醒,这也就是为什么wait notify/all 方法需要synchronized同一个对象了

再来看一下notify函数:(出一个线程对象,然后唤醒)

上图表明从头部出队列

 

也就是说,插入顺序是:_WAIT_SET 1 2 3 4 5,获取顺序也是1 2 3 4 5符合FIFO队列先进先出

再来看一下notifyAll函数:(全部唤醒)

由于迭代器用的还是DequeueWaiter,所以这个仍然是顺序出队列,并不是随机的

http://www.mmbaike.com/news/84322.html

相关文章:

  • 建设个普通的网站得多少钱抖音关键词排名推广
  • wordpress英文建站中文网站排名
  • wordpress本地环境下可以更新使用宁波seo关键词优化教程
  • 网站后台维护月薪多少软件培训机构排行榜
  • 哈尔滨网站建设效果蚁坊软件舆情监测系统
  • 网站开发的软硬环境怎么描述凡科网小程序
  • 做网站是前端还是后端网站快速排名优化报价
  • 网站实现留言功能百度一下就会知道了
  • 自己做的网站如何连接入数据库公司网址怎么制作
  • 做网站建设的公司百度视频
  • 淘宝属于什么网站怎么做seo广州工作好吗
  • wordpress手机客服插件网站外链的优化方法
  • 校庆网站建设策划书范文谷歌搜索引擎入口2023
  • 网页制作工具按其制作方式分可以分为优化二十条
  • 微博网站模板 css有哪些搜索引擎
  • 软装设计公司排名优化大师最新版下载
  • 网站建设订单中国推广网
  • 网站建设评标办法常用的关键词挖掘工具有哪些
  • 嘉兴做网站建设的公司东莞网络推广及优化
  • 杭州市网站建设公司seo搜索引擎优化简历
  • 英文wordpress转中文乱码seo专业培训seo专业培训
  • 做网站是否需要自购服务器销售成功案例分享
  • 网站建设百科网络推广推广外包服务
  • 做视频网站用什么源码深圳网站seo地址
  • 生物制药公司网站模板正规seo一般多少钱
  • 兰溪做网站关于seo的行业岗位有哪些
  • 做一个苹果app多少钱企业seo
  • 免费建商城网站哪个好大数据网站
  • 网络营销专业就业方向手机优化什么意思
  • 深圳app开发外包seo优化服务价格