- 论坛徽章:
- 0
|
注释的部分是我第一次写的程序,我现在的问题有两个:
第一,用TreeSet的时候,如果想改变它默认的排序顺序,是不是应该自定义一个类来实现Comparable接口,那一定要实现它的一个compareTo()方法,那为什么还要写hashcode()和equals()两个方法?
第二,我如果写成现在的这个样子(不包含注释的那个新代码),我理解的是按TreeSet的默认方式进行排序,那为什么就不用实现Comparable接口呢?
import java.util.*;
public class CollectionTest1{
public static void main( String[] args ){
TreeSet set = new TreeSet();
int[] Array = { 4,7,2,8,0,1, 5} ;
for( int i = 0 ; i < Array.length ; i++ ){
//set.add( new MyNumber( array ) );
set.add( new Integer(Array) );
}
System.out.println( "size = " + set.size() );
System.out.println( "size = " + set.size() );
Iterator i = set.iterator();
while( i.hasNext() ){
Object o = i.next();
System.out.println( o );
}
}
}
/*class MyNumber implements Comparable{
private int i = 0 ;
public MyNumber( int i ){
this.i = i ;
}
public String toString( ){
return "" + i ;
}
public int hashCode(){
System.out.println( "invoke hashCode" );
return new Integer( i ).hashCode();
}
public boolean equals( Object o ){
System.out.println( "invoke equals" );
if( !( o instanceof MyNumber) ){
return false ;
}
MyNumber mn = ( MyNumber ) o ;
return this.i == mn.i ;
}
public int compareTo( Object o ){
if( !( o instanceof MyNumber) ){
return -1 ;
}
MyNumber mn = ( MyNumber )o ;
return mn.i - this.i ;
}
}*/ |
|