我有MyQ课
class MyQ{
Queue<Request> q = new PriorityQueue<Request>(7, new SortRequest());
QueueStorage qStorage = new QueueStorage();
public void addRequest(int siteId, int timeStamp){
try{
q = qStorage.readRequestQ();
q.add(new Request(sId, tStamp));
qStorage.writeRequestQ(q);
}catch(Exception e){
e.printStackTrace();
}
//similarly deleteRequest() and showRequest() method follows.
}
我的Request类包含两个字段int id
以及int count
setter 和 getter。
SortRequest类是这样的:
class SortRequest implements Comparator<Request>, Serializable{
public int compare(Request r1, Request r2) {
if(r1.getCount()!=r2.getCount())
return new Integer(r1.getCount()).compareTo(r2.getCount());
if(r1.getId()!=r2.getId())
return new Integer(r1.getId()).compareTo(r2.getId());
return 0;
}
}
QStorage 类类似于:
class QStorage{
Queue<Request> readReqQ = new PriorityQueue<Request>(7, new SortRequest());
public Queue<Request> readRequestQ() {
try{
FileInputStream fin = new FileInputStream("/home/winn/requestQ.ser");
ObjectInputStream ois = new ObjectInputStream(fin);
readReqQ = (Queue)ois.readObject();
}
catch(Exception e){
return null;
}
return readReqQ;
}
public void writeRequestQ(Queue<Request> rq){
Queue<Request> requestQ = rq;
try{
FileOutputStream fos = new FileOutputStream("/home/winn/requestQ.ser");
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(requestQ);
System.out.println("done");
}catch(Exception e){
e.printStackTrace();
}
}
}
而且我在每次使用对象输入/输出流的添加/轮询操作之后将此队列存储在文件中。在添加元素时,我首先读取存储的条目,然后添加新条目并再次将其存储回来。
约束是 id 应该是唯一的,两个或多个 id 的计数可以相同/不同。所以我正在对 count 参数进行排序,但如果 count 相同,那么我应该得到排序顺序,使得较低的 id 应该在较高的 id 之前。
我最初在我的 linux 系统上尝试了这个程序,它可以正常工作并且按照我的期望正确地给出排序顺序。但是后来不知何故,我删除了所有类文件并创建了一个新文件进行存储,现在相同的代码(重新编译后)给了我完全奇怪的结果。它甚至没有根据计数参数进行排序。为什么会这样?
然后我在我的 Windows 7 系统上尝试了相同的代码,它再次开始产生正确的结果。为什么会有这种奇怪的行为?请帮忙。谢谢。