如果util.date的日期是单个数字,则按util.date字段排序列表不正确排序

时间:2016-10-03 12:29:43

标签: java date

下面是我的pojo课程

import java.util.Date;
public class SortingDate implements Comparable<SortingDate> {

    private Date date;
    private String type;
    private String motion;
    private Date startDateTime;
    private Date endDateTime;
    public Date getDate() {
        return date;
    }
    public void setDate(Date date) {
        this.date = date;
    }
    public String getType() {
        return type;
    }
    public void setType(String type) {
        this.type = type;
    }

    public String getMotion() {
        return motion;
    }
    public void setMotion(String motion) {
        this.motion = motion;
    }
    public Date getStartDateTime() {
        return startDateTime;
    }
    public void setStartDateTime(Date startDateTime) {
        this.startDateTime = startDateTime;
    }
    public Date getEndDateTime() {
        return endDateTime;
    }
    public void setEndDateTime(Date endDateTime) {
        this.endDateTime = endDateTime;
    }

    @Override
    public int compareTo(SortingDate o) {
        return getStartDateTime().compareTo(o.getStartDateTime());
    }   
}

我正在尝试按StartDateTime字段按升序排序。当我尝试将样本日期放在ex:2015-07-01时,如果我的日期是两位数它正在正确排序,那么它不会对此实例进行排序。

我的实施如下:

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.List;

public class SortingDateImpl {
public static void main(String[] args) {
    DateFormat formatter = new SimpleDateFormat("yyyy-mm-dd");

    List<SortingDate> list = new ArrayList<>();
    try{
    SortingDate MO1 = addInstance("1-10-15","DAY","AREWR-DEP",formatter.parse("2015-06-10"),formatter.parse("2015-06-11"));
    SortingDate MO21 = addInstance("1-10-15","DAY","ARERR",formatter.parse("2015-06-13"),formatter.parse("2015-06-11"));
    SortingDate MO22 = addInstance("1-10-15","Evening","DSAEP",formatter.parse("2015-06-14"),formatter.parse("2015-06-11"));
    SortingDate MO31 = addInstance("1-10-15","Evening","AASDRR",formatter.parse("2015-06-23"),formatter.parse("2015-06-11"));
    SortingDate MO32 = addInstance("1-10-15","Night","AADSDRR",formatter.parse("2015-06-15"),formatter.parse("2015-06-11"));
    SortingDate MO33 = addInstance("1-10-16","DAY","ARASDFR",formatter.parse("2015-06-19"),formatter.parse("2015-06-11"));
    SortingDate MO34 = addInstance("1-10-16","Evening","DEADSEP",formatter.parse("2015-07-01"),formatter.parse("2015-06-11"));
    SortingDate MO41 = addInstance("1-10-16","Night","AGHGFDSR",formatter.parse("2015-06-24"),formatter.parse("2015-06-11"));
    SortingDate MO42 = addInstance("1-10-16","DAY","ARWERR",formatter.parse("2015-06-29"),formatter.parse("2015-06-11"));
    SortingDate MO43 = addInstance("1-10-16","Evening","DDFGP",formatter.parse("2015-06-23"),formatter.parse("2015-06-11"));
    SortingDate MO51 = addInstance("1-10-15","DAY","ARRER",formatter.parse("2015-06-11"),formatter.parse("2015-06-11"));
    SortingDate MO52= addInstance("1-10-15","Evening","ARERR",formatter.parse("2015-06-17"),formatter.parse("2015-06-11"));
    SortingDate MO53 = addInstance("1-10-15","Night","ARRYTR",formatter.parse("2015-06-30"),formatter.parse("2015-06-11"));
    SortingDate MO54 = addInstance("1-10-16","DAY","ARYRRR",formatter.parse("2015-06-26"),formatter.parse("2015-06-11"));
    list.add(MO1);
    list.add(MO21);
    list.add(MO22);
    list.add(MO31);
    list.add(MO32);
    list.add(MO33);
    list.add(MO34);
    list.add(MO41);
    list.add(MO42);
    list.add(MO43);
    list.add(MO51);
    list.add(MO52);
    list.add(MO53);
    list.add(MO54);
    for(SortingDate sortingDate:list){
        Collections.sort(list);
        System.out.println(sortingDate.getStartDateTime().toString());
    }

    }catch(ParseException pe){
        pe.printStackTrace();
    }

}

private static SortingDate addInstance(String mDate,String mType,String mPortion,Date startdatetime,Date enddatetime) throws ParseException{
    DateFormat formatter = new SimpleDateFormat("yyyy-mm-dd");
    SortingDate workUnitBoxInstance = new SortingDate();
    workUnitBoxInstance.setDate(formatter.parse(mDate));
    workUnitBoxInstance.setType("DAY");
    workUnitBoxInstance.setMotion(mPortion);
    workUnitBoxInstance.setStartDateTime(startdatetime);
    workUnitBoxInstance.setEndDateTime(enddatetime);
    return workUnitBoxInstance;

}
}

输出:

Sat Jan 10 00:06:00 IST 2015
Sat Jan 10 00:06:00 IST 2015
Sun Jan 11 00:06:00 IST 2015
Tue Jan 13 00:06:00 IST 2015
Wed Jan 14 00:06:00 IST 2015
Thu Jan 15 00:06:00 IST 2015
Sat Jan 17 00:06:00 IST 2015
Mon Jan 19 00:06:00 IST 2015
Fri Jan 23 00:06:00 IST 2015
Fri Jan 23 00:06:00 IST 2015
Sat Jan 24 00:06:00 IST 2015
Mon Jan 26 00:06:00 IST 2015
Thu Jan 29 00:06:00 IST 2015
Fri Jan 30 00:06:00 IST 2015

2 个答案:

答案 0 :(得分:3)

尝试提取循环的排序方法!

Collections.sort(list);
for(SortingDate sortingDate:list){
    System.out.println(sortingDate.getStartDateTime().toString());
}

@assylias的评论是真的!

mm是几分钟 MM适用于月份

您应该将格式"yyyy-MM-dd"用于格式化程序

答案 1 :(得分:1)

Answer by dams是正确的。

此外,您的"yyyy-mm-dd"解析模式与输入字符串"1-10-15"不匹配。

你在这里工作太辛苦,使用了错误的课程。

您正在使用现在由java.time类取代的麻烦的旧遗留日期时间类。

您使用日期时间类java.util.Date来表示仅限日期的值。您的00:00:00对象中隐式设置了时间Date到UTC时区。你使用名为“datetime”的变量实际上意味着保留仅限日期的值(令人困惑和误导)。

有时您使用符合ISO 8601标准(YYYY-MM-DD)的字符串,有时则不会。我建议你严格遵守标准格式。

LocalDate

LocalDate类表示没有时间且没有时区的仅限日期的值。

默认情况下,java.time类使用ISO 8601格式。因此无需指定格式化模式。因此,您可以将formatter对象和所有来电放到formatter.parse

LocalDate ld = LocalDate.parse( "2015-06-29" );

LocalDate类实现了ComparablecompareTo方法。

关于java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧日期时间类,例如java.util.Date.Calendar和&amp; java.text.SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。

大部分java.time功能都被反向移植到Java 6&amp; ThreeTen-Backport中的7,并进一步适应Android中的ThreeTenABP(见How to use…)。

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore