<< Chapter < Page | Chapter >> Page > |
If you selected the following, you are correct:
D. Tom TOM Joe JOE Bill BILL
The overall structure of this program is very similar to programs that I have discussed in previous modules. Therefore, I will concentrate on thoseaspects of this program that differentiate it from the programs in previous modules.
The code in Listing 2 instantiates a new TreeSet object, by providing a reference to an anonymous object that implements the Comparator interface. That object is instantiated from the class named TheComparator . It is the Comparator object that will be of most interest to us in this module.
Listing 2 . A new TreeSet object with a Comparator. |
---|
Collection ref;
ref = new TreeSet(new TheComparator());Populator.fillIt(ref);
iter = ref.iterator();while(iter.hasNext()){
System.out.print(iter.next() + " ");}//end while loop |
After the TreeSet object is instantiated, it is passed to a method named fillIt where the TreeSet collection is populated with the names of several people.
As shown by the code in Listing 2 , after the TreeSet collection is populated, an Iterator is obtained for that collection and used to display the contents of the collection. The output produced by the programis shown below :
Tom TOM Joe JOE Bill BILL
We will need to compare this output with the names used to populate thecollection to appreciate the true significance of the use of the Comparator object.
At this point, it is worth pointing out that the six names contained in the collection are returned by the iterator in descending order , taking the significance of upper and lower case into account. In other words, namesbeginning with letters that are high in the alphabet occur before names beginning with letters that are lower in the alphabet. In addition, namescontaining lower case characters appear before the same names containing only upper case characters.
Listing 3 shows the method named fillIt that was used to populate the collection with references to six String objects. As you can see, the names weren't added in any particular order.
As you can also see by comparing Listing 3 with the output shown above , all six names that were added to the collection were displayed in the output, but ina different order from the order in which they were added. (Names with the same spelling but different case were not considered to be duplicates insofar asthe contract for the set was concerned.)
Listing 3 . The fillIt method. |
---|
public static void fillIt(Collection ref){
ref.add("Joe");ref.add("Bill");
ref.add("Tom");ref.add("JOE");
ref.add("BILL");ref.add("TOM");
}//end fillIt() |
That brings us to the class from which the Comparator object was instantiated. The beginning portion of that class is shown in Listing 4 .
Listing 4 . Beginning of the class named TheComparator. |
---|
class TheComparator implements Comparator,Serializable{public int compare(Object o1,Object o2){
if(!(o1 instanceof String))throw new ClassCastException();
if(!(o2 instanceof String))throw new ClassCastException(); |
Notification Switch
Would you like to follow the 'Object-oriented programming (oop) with java' conversation and receive update notifications?