多线程 producer consumer问题

easyroom 2011-01-26 07:47:16
场景介绍。系统中有一个导入功能,导入后要对数据进行一系列处理。处理逻辑较复杂,所以用一个线程延时来处理。现在的情形就是导入后就创建一组任务,任务加入待处理列表中。处理的线程进行处理,没有任务时就等待,直到有任务进来再唤醒。


现在wait notify都是手工做的,代码乱的没法看了。有经验的筒子们给点建议,有啥现成的Lib啊,模式啊,尽量拍啊
...全文
89 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
easyroom 2011-01-27
  • 打赏
  • 举报
回复
导入的数据存在表A中,线程的任务是根据业务逻辑,设置表A中某些字段的值
导入的方法是有事务控制的。事务控制是由spring的taransaction manager管理的。是加在方法上的。向任务队列中添加任务是在导入方法中做得。导入方法与线程中的操作同时执行的话会报一个数据库异常。所以要在开始导入前,让线程暂停,在结束之后再恢复它
  • 打赏
  • 举报
回复
等你什么通知?具体什么需求!
easyroom 2011-01-26
  • 打赏
  • 举报
回复
LinkedBlockingQueue 不错,但是还有点不满足需要


1,我不希望put进去task之后立刻开始处理,我希望它等我通知的时候在开始
  • 打赏
  • 举报
回复
LinkedBlockingQueue 属于 Java 集合框架类库之一,并且在 java.util.concurrent 下,其是线程安全的,可以被多个线程并发地进行处理。
  • 打赏
  • 举报
回复
把任务添加到 LinkedBlockingQueue 中去,另启一个线程从这个队列中 take 出任务就可以了,没有任务时 take 自己会阻塞掉,如果队列满了,在 put 时就会阻塞掉。看任务的处理速度,以及数量有多少来设定这个 Queue 的长度。
easyroom 2011-01-26
  • 打赏
  • 举报
回复
看来着,好像不太合用啊

我处理的行为优先级比较低,不打算让它多线程跑,一个线程慢慢做就ok了
iambic 2011-01-26
  • 打赏
  • 举报
回复
java.util.concurrent.Executor
java.util.concurrent.Executors
java.util.concurrent.ExecutorService

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧