2 回答
TA贡献1878条经验 获得超4个赞
释放是个轻量操作。如果你实在纠结阻塞时间我有个思路。
因为你的对象列表(假设叫ol)不是线程安全的,所以每次操作都会锁住ol。
那可以单开一个守护线程轮询jvm内存,一旦内存到达这个阀值就可以认为快用光了,然后将一个全局变了标记为true。
当你的工作线程发现这个全局变量为true后,在保存新对象到ol前,将ol最前面的几个对象(1个或2个,不用多因为在轮询线程没发现内存回复前其他工作线程仍会释放)释放,然后保存新的。
那个轮询内存的守护线程发现内存低于指定的阀值后在将全局变量设为false,这样新的工作线程不会在有释放操作。
这样的话你完全没有引入任何需要锁ol的线程,你ol的阻塞率还是你原来的工作线程。由于轮询内存线程是守护线程你也不用操心优雅的终止问题。
更新
突然发现你问的是如果让线程运行指定的时间。。。。
线程卡在while前记一下开始时间,你循环里根据开始时间计算耗时,达到你指定的时候跳出或sleep都行。
TA贡献1859条经验 获得超6个赞
工作线程和释放资源的线程同时只能有一个操作对象列表
这个前提决定了你必须使用synchronized块对操作这个列表的逻辑做保护,这个没得说;
剩下的问题就是:如何让回收线程操作列表的时间更短?
我的思路是这样的:很简单,你的回收线程在操作列表时,只做一件事情:把该回收的对象移出列表,放到另一个地方去(比如另一个列表,"列表2")
仅仅是“移出”的话,这个操作是非常快的,不知道你这个列表有多大,一般情况都能瞬间完成;
然后让工作线程去操作列表,回收线程慢慢来处理"列表2"中的回收工作, 互不干扰;
如果你的对象列表确实很极端地大,那么你可以将回收线程设计成"主-次"线程2层结构,其中主线程开启子线程对列表做移出操作,并持有子线程对象的应用;
而子线程,实现了interrupt方法,在方法中抛出一个你自定义的exception;
主线程在启动子线程后,sleep(你认为合适的时间),醒来时若发现子线程还未结束,就调用子线程的interrupt方法
添加回答
举报