赞
踩
前面以篇文章浅谈了一下我对这个问题的思考方法,当初只是有了一个大体的实现方式,而真正实行起来还是有很多的小细节:
关于问题的解决用到的核心思想我简单的阐述一下:将线程offer到一个有线程安全的队列当中;在执行线程任务的时候判断当前线程是否是我队列中的额线程,如果是,你该干嘛就干嘛,如果不是我原始的想法是主动放弃本次cpu的竞争机会,于是浅试了一下yiled方法,但是yiled不会释放锁资源呀,这也就是说,你虽然不和其它线程竞争,但是你一直不释放资源,即使别的线程抢到了锁的使用权,也拿不到锁,那我的初衷还是没有实现;于是我采用了wait方法,因为这个wait可以释放锁资源,然后在没被唤醒的情况下也不会参与竞争。那涉及到了wait就必须有notify呀,为了不产生全部都进入等待啊队列的情况,我果断的选择了notifyAll这个方法,结果出现了异常,我也没弄明白为啥会出现异常,但是不管怎么说,整体效果已经实现了,但是细节处理,和程序优化还是有待改进:
实现代码:
题目要求:
核心代码:
运行结果:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。