excelexportentity中设置null不显示的方法_一般人不知道的线程间数据交换Exchanger

线程间的数据共享除了定义一个共享数据然后各个线程去访问这种方式外,还可以使用Exchanger交换数据。

简单案例

首先看看Exchanger的运用,Exchanger最简单的测试代码,如下图:

4f5f846c7c8c9168d7c9461f77aa5910.png

对应打印的结果如下:

线程2创建对象java.lang.Object@3f6d4362

线程1创建对象java.lang.Object@c986ad7

线程2得到的类java.lang.Object@c986ad7

线程1得到的类java.lang.Object@3f6d4362

可以看出来线程2创建的对象与线程1得到的线程是同一个对象,也就是他们指向的是同一个引用。

Exchanger源码分析

Exchanger只提供了两个exchange方法,一个是只带交换的数据参数,另外一个不仅有数据参数,还有时间限制,这也从侧面说明exchange是一个阻塞线程的方法,并且可以指定阻塞时间,这里我们先分析下不带时间参数的exchange方法,源码分析主流程如下图:

3c472d4662c28a7538e6e3d1217540cb.png

左边是exchange方法的代码流程图,比较简单可以明显的看出来主要依靠两个方法slotExchange与arenaExchange方法,流程主要有两步,首先尝试从slotExchange方法获取值,如果获取为null则再从arenaExchange方法获取,当返回还是null时则抛出中断异常,否则最终返回结果

slotExchange源码分析

上图中右边的分析图是slotExchange方法的主要代码图,再分析这个方法前先说明一下Exchanger的一个内部类Node,Node有7个属性,这里先说明三个属性item(创建node线程要交换出去的值)、match(创建node线程要获取的值)、parked(创建node的线程);每个线程再执行到Exchanger方法后都会创建一个Node。

理解这个基本概念后,再来快速过一下slotExchange方法流程,方法包含两个循环,第一个循环分析如下:

首先判断Exchanger的slot是否为null,如果不为空则尝试修改slot值为null,如果修改成功则返回slot的item,并设置slot的match,并唤醒slot的线程,交换成功。如果设置失败则说明有其他线程正在修改slot,即存在竞争,这是会判断机器的CPU数,如果大于1则会初始化Exchanger的Node[] arena(这个是下个方法说明),进入下一个循环。

如果slot为null则判断arena是否为null,如果不为null则直接返回null,表示由arenaExchange去执行。

如果都不是则尝试当前线程的node的item设置为要交换的值,同时尝试设置为slot,设置成功则跳出循环,失败则进入下次循环;

第一个循环主要包含两步,如果slot不为null则尝试交换值,交换成功就返回,否则就尝试设置slot的值,设置成功就跳出循环;在cpu是多个的情况下又存在竞争的情况下会再arenaExchange去处理。

这个循环如果跳出来了则说明设置slot成功,那么当前线程只需要等待node的match不为null就行,所以第二个循环的判断条件就是node的match不为null,如果为null就挂起,当唤醒的时候再判断,直到node的match不为null则返回match的值。

分析arenaExchange方法

在slotExchange方法中会在存在竞争修改slot并且运行程序的机器的CPU大于1时会初始化Node[] arena属性,在第二次修改slot还存在竞争失败时就会返回null,这个时候就到了arenaExchange方法上场了。

arenaExchange也是一个for的无限循环,每次取出当前线程的Node来获取进行处理,这里再介绍node一个属性index,用来标记nodearena数组的位置,处理流程的简单分析如下:

首先根据node的index获取j(计算方法:index<<7+ABASE(1<<7的常量),原因后面特别说明),如果不为null则尝试修改arena的第j项为null,如果成功则返回arena[j]的node的item的值,并设置match,最后唤醒node保存的线程。

第二步如果node为null则把当前线程的node的item设置为要交换出去的值,然后尝试修改arena[j]的值为当前线程的node,如果修改成功则循环判断match的值,当不为null则返回值,否则判断线程中断等条件后则挂起线程,等唤醒再判断。

第三步也就是node不为null,但是在第一步更新失败后,会根据node的bound与Exchange的bound等对比,计算index的值,有时会增长有时会减少,然后进入下一个循环判断。

总结这三步主要目的如下,首先是尝试从arena找一个节点来交换数据,如果交换成功则唤醒对应的线程并返回交换结果,如果交换失败则更新index,再次尝试寻找并交换,如果在找到的arena[j]为null则尝试新建一个node并保存进arena,挂起线程等待唤醒

对之前的arena的j特别说明,把index扩大再作为数组的索引,原因是内存在加载数组一个元素时会把附近的也加载,而修改过后会把加载出来的设置为过期,为了避免这种浪费在数组间隔一定位置在设置值。

总结

Exchanger利用一个Node类型的属性slot实现线程间的交换,如果slot为null则初始化一个并设置item为需要交换的值,然后挂起,当其他线程进来的时候看到slot为null则取出node的item值,然后把自己要交换的值设置进match上,然后唤醒node中线程。

利用一个属性也够了,但是在并发的情况下吞吐量并不高,所以又建了一个Node的数组arena,线程在arena一个个找不为null的值,尝试修改直到修改成功,则获取node的item,再设置match并唤醒线程。如果找到的为null则自己主动new一个node并设置item,然后挂起等待唤醒。

Java程序员日常学习笔记,如理解有误欢迎各位交流讨论!

08d68d556716464ce4cbe319907f0111.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/360321.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

画毛毛虫代码计算机图形学,考试计算机图形学考试计算机图形学.docx

考试计算机图形学考试计算机图形学计算机图形学大题第四章1个。第六章2个第七章1个第一章4、比较个人计算机与工作站的图形功能个人计算机仅限于符合二维&#xff0c;又是单任务操作方式工作站可处理二、三维&#xff0c;多任务操作方式区别个人计算机工作站显示分别率640 X 48…

网卡驱动程序之编写虚拟网卡(二)

一、virt_net.c /** 参考 drivers\net\cs89x0.c*/#include <linux/module.h> #include <linux/errno.h> #include <linux/netdevice.h> #include <linux/etherdevice.h> #include <linux/kernel.h> #include <linux/types.h> #include <…

冷热rx-java可观察

我自己对“热的和冷的可观察的”的理解是不稳定的&#xff0c;但这是我到目前为止所了解的&#xff01; 冷观测 考虑一个返回rx-java Observable的API&#xff1a; import obs.Util; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import rx.Observable; import…

布尔表达式的语法及语义分析程序_XSS语义分析的阶段性总结(一)

作者&#xff1a;Kale 合天智汇前言由于X3Scan的研发已经有些进展了&#xff0c;所以对这一阶段的工作做一下总结&#xff01;对于X3Scan的定位&#xff0c;我更加倾向于主动被动的结合。主动的方面主要体现在可以主动抓取页面链接并发起请求&#xff0c;并且后期可能参考XSStr…

计算机上的usb设备是什么东西,联接一个USB的线在电脑桌上方便插U盘的东西叫什么?...

HUB&#xff0c;即俗称的集线器。它是一个多端口的转发器&#xff0c;当以HUB为中心设备时&#xff0c;网络中某条线路产生了故障&#xff0c;并不影响其它线路的工作。所以HUB在局域网中得到了广泛的应用。大多数的时候它用在星型与树型网络拓扑结构中&#xff0c;以RJ45接口与…

【黑金原创教程】【TimeQuest】【第二章】TimeQuest模型角色,网表概念,时序报告...

声明&#xff1a;本文为黑金动力社区&#xff08;http://www.heijin.org&#xff09;原创教程&#xff0c;如需转载请注明出处&#xff0c;谢谢&#xff01; 黑金动力社区2013年原创教程连载计划&#xff1a; http://www.cnblogs.com/alinx/p/3362790.html 《FPGA那些事儿--Tim…

设置springboot日志级别_Spring Boot 日志框架实践

概述Java应用中&#xff0c;日志一般分为以下5个级别&#xff1a;ERROR 错误信息WARN 警告信息INFO 一般信息DEBUG 调试信息TRACE 跟踪信息Spring Boot使用Apache的Commons Logging作为内部的日志框架&#xff0c;其仅仅是一个日志接口&#xff0c;在实际应用中需要为该接口来指…

简单的类来测量延迟

这是我编写的用于测量延迟的非常简单的类。 HDRHistogram并不是劳斯莱斯解决方案&#xff0c;但是如果您只想向项目添加一个类&#xff0c;则可以很好地解决问题。 这是一个简单的测试程序&#xff0c;向您展示其用法&#xff1a; package util;public class LatencyMeasureE…

计算机加分乘法套用,8+8+8+8+8写成乘法算式要怎样写?小学数学为何这么死板?...

88888写成乘法算式只能写8x5不能写5x8吗&#xff1f;小学数学为何这么死板&#xff1f;这个题目来自于某小学的期考试卷&#xff0c;是个填空题&#xff0c;88888写成乘法算式时给了两个空( )和( )&#xff0c;就有人提出来只能写8x5不能写5x8&#xff0c;所以应该只给一个空。…

债券价格和通胀率

一般规律&#xff0c;通胀率于债券收益率正相关。 当通胀率较高时&#xff0c;市场会降低对债券的需求&#xff08;固定息票&#xff09; 》 导致债券价格下跌&#xff0c;收益率上升。转载于:https://www.cnblogs.com/xispace/p/3383357.html

净值:测试编码器/解码器

我最近与Netty进行了一些合作&#xff0c;并且按照此出色的教程中的说明构建了编码器/解码器管道&#xff0c;以测试编码器和解码器是否在正常工作而不必发送真实的消息。 幸运的是&#xff0c;有一个EmbeddedChannel确实使我们的生活变得非常轻松。 假设我们有一条消息“ Fo…

投影元素直接隔离_摸着夜色上露台开投影,是巴塞罗那设计师的浪漫

总有人说&#xff0c;世界为你关上一扇门&#xff0c;定会为你留有一扇窗。在家闷上个把月&#xff0c;窗户直接担起了连接人们与外界的通道。既然观众出不了门&#xff0c;那不如让加油打气的海报们&#xff0c;自己爬上墙好了——人们打开窗子就能撞上。平面设计师Ral Goi一直…

天涯明月刀7月4号服务器维护,7月8日服务器例行维护公告

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼亲爱的玩家&#xff1a;青龙乱舞区、大地飞鹰区、沧海云帆区、把酒邀月区、边城浪子区全部服务器将在7月8日6:00~10:00停机维护更新&#xff0c;&#xff0c;维护完成后上述各服务器客户端版本更新至2.1.20.23&#xff0c;给您带来…

关于ecshop中jquery与js冲突解决的方案

ECShop把AJAX事件和JSON解析的模块放在common/transport.js之中&#xff0c;可以说它也有自己封装的一套工具&#xff0c;这其实是很正常的。但恰恰的&#xff0c;在封装JSON各种方法的同时对object的模型进行了重写&#xff0c;这个就跟jQuery冲突了。因为众所周知的&#xff…

Apache Lucene的结构

不可估量的高贵的Apache软件基金会&#xff08;Apache Software Foundation&#xff09;产生了许多重要产品&#xff08;Ant&#xff0c;CouchDB&#xff0c;Hadoop&#xff0c;JMeter&#xff0c;Maven&#xff0c;OpenOffice&#xff0c;Subversion等&#xff09;&#xff0c…

comcerter无法识别串口_基于FPGA 的MXN维字符识别的实现

基于FPGA 的MXN维字符识别的实现1 概述本文的灵感来源于杨淑英老师的一张PPT&#xff08;手写数字识别&#xff09;&#xff0c;在此特别鸣谢杨淑英老师。一般机器视觉对事物是没有感知的&#xff0c;比如摄像头采集到一张苹果的图片&#xff0c;它本身是不知道那是什么东西&am…

嵌套的json ajax,通过jquery或javascript通过AJAX读取嵌套的JSON并输出到表中

我真的很想有一个快速便捷的方法来遍历JSON中的多个记录&#xff0c;每个记录都有潜在的深层嵌套。我只想输出到表。我不确定$ .each()或$ .ajax()成功的javascript方法需要通过function()传递哪些参数。所有示例似乎都使用通用词“data”或“ obj”&#xff0c;但它们使我感到…

难题:嵌套computeIfAbsent

总览 Java 8库在地图上有一个新方法&#xff0c;computeIfAbsent。 这是一种非常有用的将地图变成与键关联的对象的缓存的方法。 但是&#xff0c;您可能没有考虑过一种组合。 如果您在内部调用computeIfAbsent会发生什么。 map.computeIfAbsent(Key.Hello, s -> {map.com…

python扩展文件_1. 使用 C 或 C++ 扩展 Python

1.12.给扩展模块提供C API很多扩展模块提供了新的函数和类型供Python使用&#xff0c;但有时扩展模块里的代码也可以被其他扩展模块使用。例如&#xff0c;一个扩展模块可以实现一个类型 "collection" 看起来是没有顺序的。就像是Python列表类型&#xff0c;拥有C AP…

swal ajax,Sweetalert详细介绍

好长时间没有更新文章了&#xff0c;年底工作比较忙&#xff0c;确实是没有时间来写文章。今天忙里偷闲&#xff0c;总结了一款前端提示框的插件——sweetalert——推荐给大家。Sweetalert安装Sweetalert官方为我们提供了三种安装方式&#xff1a;方法一 通过bower安装$ bower …