一种中心服务中同步状态的方法
2016-06-14 17:08
381 查看
问题
在客户端中心化服务(单例)中,可能会多次进行同一个耗时服务,比如说和服务端同步状态。在进行同步时,如果有请求进来,理论上是不需要真正执行的,仅需要等待正在进行的请求。解决
其实是一个时序的问题,如果请求发起比获得结果要早,就可以直接使用结果。那么,中心服务中使用ThreadLocal存储一下发起请求的时机,进入一个锁住的同步过程,同步过程后更新结果和结果时间即可。
ThreadLocal的释放问题
代码
public class Work { private static Work sInstance = new Work(); public static Work getInstance() { return sInstance; } private ThreadLocal<Long> mRequestTime = new ThreadLocal<>(); private int mResult; private long mResultTime; public void doWork() { mRequestTime.set(SystemClock.uptimeMillis()); realDo(); } private synchronized void realDo() { if (mRequestTime.get() < mResultTime) { return; } try { Thread.sleep(new Random(System.currentTimeMillis()).nextInt(250)); } catch (InterruptedException e) { e.printStackTrace(); } mResult = new Random(System.currentTimeMillis()).nextInt(); mResultTime = SystemClock.uptimeMillis(); } }
相关文章推荐
- js分享到第三方平台
- 浅谈算法和数据结构: 二 基本排序算法
- 第23课:Spark Streaming初始化和关闭源码图解
- MySQL 5.6 & 5.7最优配置模板
- Ueditor图片上传不能兼容微信浏览器的解决方案
- centos 5.0 编译安装apache 2.2.6+php5.2.5+mysql5.0.46+ZEND
- C# WebBrowser控件打开Echarts无效解决办法
- 344. Reverse String
- 浅谈算法和数据结构: 一 栈和队列
- VSTO 右击菜单 系统类型分类 (Application.CommandBars)
- CoreLocation框架的使用---地理编码
- sysctl -p 的使用
- RecyclerView的简单使用(1)
- Java Socket通信(TCP/UDP)
- “彩虹花”python-matploylib模块
- C++中的static关键字
- 省略超出文章部分 超出部分加“…” 展开收起
- Android Studio Git 版本控制 on Windows10--从系统配置到具体使用
- Linux底下在Eclipse中将Java工程生成Web Service接口(Axis和Axis2)
- oracle ebs database升级11.1.0.7到11.2.04