Mercurial > hg > Database > Alice
view src/alice/topology/manager/keeparive/ListManager.java @ 328:370a2f63944f
add ListManager Test
author | sugi |
---|---|
date | Tue, 11 Feb 2014 16:10:23 +0900 |
parents | 235f6d0994df |
children | d35ff0f588e8 |
line wrap: on
line source
package alice.topology.manager.keeparive; import java.util.LinkedList; public class ListManager { private LinkedList<TaskInfo> list = new LinkedList<TaskInfo>(); public LinkedList<TaskInfo> getTaskList() { return list; } public void addTask(TaskInfo newInfo) { TaskExecuter exec = TaskExecuter.getInstance(); TaskInfo nowTask = exec.getNowTask(); if (nowTask == null) { // active task is nothing long remainingTime = exec.initRemainingTime(); TaskInfo task = list.getFirst(); task.setSleepTime(task.getSleepTime() + remainingTime); add(newInfo); } else { long remainingTime = exec.getRemainingTime(); if (remainingTime > newInfo.getSleepTime()) { // active task is longer than newTask. TaskInfo task = nowTask.clone(); task.setSleepTime(remainingTime); list.addFirst(task); add(newInfo); exec.ignore(); } else { // newTask is longer than active task. newInfo.setSleepTime(newInfo.getSleepTime() - remainingTime); add(newInfo); } } } private void add(TaskInfo newInfo){ int cnt = 0; for (TaskInfo info : list){ if (info.getSleepTime() < newInfo.getSleepTime()){ newInfo.setSleepTime(newInfo.getSleepTime() - info.getSleepTime()); } else if (info.getSleepTime() == newInfo.getSleepTime()){ // newInfo.getSleepTime() - info.getSleepTime() must be Zero newInfo.setSleepTime(0); cnt++; break; } else if (info.getSleepTime() > newInfo.getSleepTime()){ info.setSleepTime(info.getSleepTime() - newInfo.getSleepTime()); break; } cnt++; } list.add(cnt, newInfo); } public void showList(){ if (TaskExecuter.getInstance().getNowTask()!=null){ System.out.print("NOW | "); System.out.print(TaskExecuter.getInstance().getNowTask().getSleepTime()); System.out.print(" | "); } for (TaskInfo info : list){ System.out.print(info.getSleepTime()); System.out.print(" | "); } System.out.println(); } }