Java任务队列的定义与代码的详细介绍

Java任务队列需要我们详细的学习,当然我们在不断的使用中还需要注意相关信息的学习。下面我们就先来看看TaskQueue(任务队列)的具体应用。下面我们就详细的学习下。

为田家庵等地区用户提供了全套网页设计制作服务,及田家庵网站建设行业解决方案。主营业务为成都网站设计、做网站、成都外贸网站建设公司、田家庵网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

在同一时刻,可能有很多任务需要执行,而程序在同一时刻只能执行一定数量的任务,当需要执行的任务数超过了程序所能承受的任务数时怎么办呢?这就有了先执行哪些任务,后执行哪些任务的规则。

TaskQueue类就定义了这些规则中的一种,它采用的是FIFO(先进先出,英文名是First In First Out)的方式,也就是按照任务到达的先后顺序执行。TaskQueue类的定义。

Java任务队列代码如下:

 
 
 
  1. import java.util.Iterator;   
  2. import java.util.LinkedList;   
  3. import java.util.List;   
  4. public class TaskQueue {   
  5. private List queue = new LinkedList();   
  6. // 添加一项任务   
  7. public synchronized void addTask(Task task) {   
  8. if (task != null) {   
  9. queue.add(task);   
  10. }   
  11. }   
  12. // 完成任务后将它从任务队列中删除   
  13. public synchronized void finishTask(Task task) {   
  14. if (task != null) {   
  15. task.setState(Task.State.FINISHED);   
  16. queue.remove(task);   
  17. }   
  18. }   
  19. // 取得一项待执行任务   
  20. public synchronized Task getTask() {   
  21. Iterator it = queue.iterator();   
  22. Task task;   
  23. while (it.hasNext()) {   
  24. task = it.next();   
  25. // 寻找一个新建的任务   
  26. if (Task.State.NEW.equals(task.getState())) {   
  27. // 把任务状态置为运行中   
  28. task.setState(Task.State.RUNNING);   
  29. return task;   
  30. }   
  31. }   
  32. return null;   
  33. }   
  34. }   
  35. import java.util.Iterator;  
  36. import java.util.LinkedList;  
  37. import java.util.List;  
  38. public class TaskQueue {  
  39. private List queue = new LinkedList();  
  40. // 添加一项任务  
  41. public synchronized void addTask(Task task) {  
  42. if (task != null) {  
  43. queue.add(task);  
  44. }  
  45. }  
  46. // 完成任务后将它从任务队列中删除  
  47. public synchronized void finishTask(Task task) {  
  48. if (task != null) {  
  49. task.setState(Task.State.FINISHED);  
  50. queue.remove(task);  
  51. }  
  52. }  
  53. // 取得一项待执行任务  
  54. public synchronized Task getTask() {  
  55. Iterator it = queue.iterator();  
  56. Task task;  
  57. while (it.hasNext()) {  
  58. task = it.next();  
  59. // 寻找一个新建的任务  
  60. if (Task.State.NEW.equals(task.getState())) {  
  61. // 把任务状态置为运行中  
  62. task.setState(Task.State.RUNNING);  
  63. return task;  
  64. }  
  65. }  
  66. return null;  
  67. }  

以上就是对Java任务队列的详细介绍。

【编辑推荐】

  1. JavaScript最让人费解的十件事
  2. 了解Java日志系统框架的设计与实现
  3. 在敏捷开发中编写高质量Java代码
  4. Java类中热替换的概念、设计与实现
  5. Python编程语言在Java中的使用效果

文章标题:Java任务队列的定义与代码的详细介绍
网页路径:http://www.csdahua.cn/qtweb/news0/268500.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网