先看一段对日期进行排序和搜索的程序,代码如下:
public class TestDateSearch {
public static void main(String[] args) {
Date[] days = new Date[5];
  days[0] = new Date(2005,3,4);
  days[1] = new Date(2004,5,3);
days[2] = new Date(2005,3,6);
days[3] = new Date(2007,2,5);
days[4] = new Date(2003,3,7);


Date d = new Date(2004,5,3);
bubbleSort(days);

for(int i=0; i<days.length; i++) {
    System.out.println(days[i]);
  }
  
System.out.println(binarySearch(days,d));

}
    
public static Date[] bubbleSort(Date[] a) {
int len = a.length ;
for(int i=0; i<len - 1; i++) {
for(int j=0; j<len - j; j++) {
if(a[j].Compare(a[j+1]) > 0) {
Date temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
return a;
}

  public static int binarySearch(Date[] days,Date d) {
   if(days.length==0) return -1;
   int startPos = 0;
   int endPos = days.length - 1;
   int m = (startPos + endPos) / 2;
  
   while(startPos <= endPos) {
   if(d.Compare(days[m])== 0) return m;
     if(d.Compare(days[m])>0) {
      startPos = m+1;
     }
     if(d.Compare(days[m])<0) {
      endPos = m-1;
     }
   }
   return -1;
  }
}class Date {
int year;
int month;
int day;
Date(int y, int m, int d) {
year = y;
month = m;
day = d;
}

public int Compare(Date d) {
return year > d.year ? 1 
       : year < d.year ? -1
       : month > d.month ? 1
       : month < d.month ? -1
       : day > d.day ? 1
       : day < d.day ? -1 : 0;

public String toString() {
return "Year:Month:Day --" + year + "-" + month + "-" + day;
}
}我比较疑惑的是:public String toString() {
return "Year:Month:Day --" + year + "-" + month + "-" + day;
       }
为什么要对toString() 进行重写,没有这段代码结果却是一些哈希代码什么的,并不是日期、  
哪位朋友能给仔细讲讲为什么要写 toString() 吗   不胜感激  另外我是刚进入论坛的新手,就不给分了 请海涵了呵呵呵