问题:
Snack类的isExpired方法实现了什么功能?
现有相当大量的snack对象(如一个长度100万的Snack对象数组)需要执行isExpired方法,执行时候发现效率低下, 请分析原因, 并给出优化方案?
为了方便交流学习, 我把完整的题目都贴出来了, 我主要的问题是第二问, 大家有没有好的办法?
代码如下:
public class Snack {
public Snack(String name, Date expirDate){
this.name = name;
this.expireDate = expireDate;
}
private String name;
private Date expireDate;
public boolean isExpired(){
Date now = new Date();
return now.compareTo(this.expireDate) > 0 ;
}
}
谢邀。
这个可以百度。当前日期如果大于该对象的expireDate就返回true。
我的算法不是很6,如果有误请轻喷:先考虑对象们的expireDate是否有序。有序可以借鉴二分查找的思路。比如是从小到大,那么如果可以找到某个对象,那么后面的对象全部返回true。