<< Chapter < Page Chapter >> Page >

The class named TheComparator

Listing 11 shows the class from which the Comparator object was instantiated.

This is essentially the same class that was used to instantiate a Comparator object in an earlier module. I discussed the compare method in detail in that module and won't repeat that discussion here.

Listing 11 . 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();int result = ((String)o1).compareTo(((String)o2)); return result*(-1);}//end compare() }//end class TheComparator

Suffice it to say at this point that this Comparator object causes the elements in the array to be sorted into reverse natural order . That term was also explained in the previous module, so I won't discuss it further here.

Display the array contents again

The code in Listing 12 was used to display the newly-sorted contents of the array.

Listing 12 . Display the contents again.
System.out.println("Custom order sorted " + "array data");display(array);

The output produced by this code is:

Custom order sorted array data Tom TOM Joe JOE Bill BILL

You will recognize this as reverse natural order for the elements contained in the array.

Could have sorted differently

It is important to note that I could have caused the sorting order to be different from reverse natural order simply by defining the rules used for comparison in the compare method shown in Listing 11 above. This makes it possible for you to sort array data into any order that you choose aslong as you can write the sorting rules into the compare method of a class that implements the Comparator interface.

Display the collection data again

Finally, in order to show that none of this has disturbed the contents of the original collection, the code in Listing 13 gets and uses an iterator to display the contents of the Vector collection.

Listing 13 . Display the collection data again.
iter = ref.iterator(); System.out.println("Collection data");while(iter.hasNext()){ System.out.print(iter.next() + " ");}//end while loop

The output produced by the code in Listing 13 is:

Collection data Joe Bill Tom JOE BILL TOM

If you compare this with the output produced by the code at the beginning of the program, you will see that the iterator still returns the elements in the Vector in the same order that they were added. Thus, modifications to the array did not disturb the contents of the Vector collection.

The bottom line

The toArray method of the Collection interface makes it possible to extract a copy of the elements in a collection into an array and tomanipulate those elements in whatever way you wish. As mentioned earlier, however, care should be exercised to make certain that the copies of thereferences to the original objects are not used to corrupt the objects.

The various versions of the sort method in the Arrays class make it possible to sort the contents of arrays in a variety of different ways.

Run the program

I encourage you to copy the code from Listing 1 . Paste the code into your Java editor. Thencompile and execute it.

Run the program and observe the results. Experiment with the code. Make changes, run the program again, and observe the results of your changes. Make certain that youcan explain why your changes behave as they do.

Summary

In this module, I taught you how to extract the contents of a collection into an array and how to use a Comparator to sort the contents of the array into reverse natural order .

Although I elected to use reverse natural order for purposes of illustration, I could have sorted the array into some other order simply bydefining the comparison rules in the compare method of the Comparator class differently.

In order to further expand your knowledge of array sorting, I also sorted the array into natural order without the use of a Comparator .

Sorting the contents of the array did not disturb the contents of the Vector collection from which the contents of the array were derived.

What's next?

In the next module, I will show you how to use the sort method of the Collections class along with a Comparator object to sort the contents of a List .

Miscellaneous

This section contains a variety of miscellaneous information.

Housekeeping material
  • Module name: Java4120: The Comparator Interface, Part 4
  • File: Java4120.htm
  • Published: 05/07/13
Disclaimers:

Financial : Although the Connexions site makes it possible for you to download a PDF file for thismodule at no charge, and also makes it possible for you to purchase a pre-printed version of the PDF file, you should beaware that some of the HTML elements in this module may not translate well into PDF.

I also want you to know that, I receive no financial compensation from the Connexions website even if you purchase the PDF version of the module.

In the past, unknown individuals have copied my modules from cnx.org, converted them to Kindle books, and placed them for sale on Amazon.com showing me as the author. Ineither receive compensation for those sales nor do I know who does receive compensation. If you purchase such a book, please beaware that it is a copy of a module that is freely available on cnx.org and that it was made and published withoutmy prior knowledge.

Affiliation : I am a professor of Computer Information Technology at Austin Community College in Austin, TX.

-end-

Questions & Answers

how did you get 1640
Noor Reply
If auger is pair are the roots of equation x2+5x-3=0
Peter Reply
Wayne and Dennis like to ride the bike path from Riverside Park to the beach. Dennis’s speed is seven miles per hour faster than Wayne’s speed, so it takes Wayne 2 hours to ride to the beach while it takes Dennis 1.5 hours for the ride. Find the speed of both bikers.
MATTHEW Reply
420
Sharon
from theory: distance [miles] = speed [mph] × time [hours] info #1 speed_Dennis × 1.5 = speed_Wayne × 2 => speed_Wayne = 0.75 × speed_Dennis (i) info #2 speed_Dennis = speed_Wayne + 7 [mph] (ii) use (i) in (ii) => [...] speed_Dennis = 28 mph speed_Wayne = 21 mph
George
Let W be Wayne's speed in miles per hour and D be Dennis's speed in miles per hour. We know that W + 7 = D and W * 2 = D * 1.5. Substituting the first equation into the second: W * 2 = (W + 7) * 1.5 W * 2 = W * 1.5 + 7 * 1.5 0.5 * W = 7 * 1.5 W = 7 * 3 or 21 W is 21 D = W + 7 D = 21 + 7 D = 28
Salma
Devon is 32 32​​ years older than his son, Milan. The sum of both their ages is 54 54​. Using the variables d d​ and m m​ to represent the ages of Devon and Milan, respectively, write a system of equations to describe this situation. Enter the equations below, separated by a comma.
Aaron Reply
find product (-6m+6) ( 3m²+4m-3)
SIMRAN Reply
-42m²+60m-18
Salma
what is the solution
bill
how did you arrive at this answer?
bill
-24m+3+3mÁ^2
Susan
i really want to learn
Amira
I only got 42 the rest i don't know how to solve it. Please i need help from anyone to help me improve my solving mathematics please
Amira
Hw did u arrive to this answer.
Aphelele
hi
Bajemah
-6m(3mA²+4m-3)+6(3mA²+4m-3) =-18m²A²-24m²+18m+18mA²+24m-18 Rearrange like items -18m²A²-24m²+42m+18A²-18
Salma
complete the table of valuesfor each given equatio then graph. 1.x+2y=3
Jovelyn Reply
x=3-2y
Salma
y=x+3/2
Salma
Hi
Enock
given that (7x-5):(2+4x)=8:7find the value of x
Nandala
3x-12y=18
Kelvin
please why isn't that the 0is in ten thousand place
Grace Reply
please why is it that the 0is in the place of ten thousand
Grace
Send the example to me here and let me see
Stephen
A meditation garden is in the shape of a right triangle, with one leg 7 feet. The length of the hypotenuse is one more than the length of one of the other legs. Find the lengths of the hypotenuse and the other leg
Marry Reply
how far
Abubakar
cool u
Enock
state in which quadrant or on which axis each of the following angles given measure. in standard position would lie 89°
Abegail Reply
hello
BenJay
hi
Method
I am eliacin, I need your help in maths
Rood
how can I help
Sir
hmm can we speak here?
Amoon
however, may I ask you some questions about Algarba?
Amoon
hi
Enock
what the last part of the problem mean?
Roger
The Jones family took a 15 mile canoe ride down the Indian River in three hours. After lunch, the return trip back up the river took five hours. Find the rate, in mph, of the canoe in still water and the rate of the current.
cameron Reply
Shakir works at a computer store. His weekly pay will be either a fixed amount, $925, or $500 plus 12% of his total sales. How much should his total sales be for his variable pay option to exceed the fixed amount of $925.
mahnoor Reply
I'm guessing, but it's somewhere around $4335.00 I think
Lewis
12% of sales will need to exceed 925 - 500, or 425 to exceed fixed amount option. What amount of sales does that equal? 425 ÷ (12÷100) = 3541.67. So the answer is sales greater than 3541.67. Check: Sales = 3542 Commission 12%=425.04 Pay = 500 + 425.04 = 925.04. 925.04 > 925.00
Munster
difference between rational and irrational numbers
Arundhati Reply
When traveling to Great Britain, Bethany exchanged $602 US dollars into £515 British pounds. How many pounds did she receive for each US dollar?
Jakoiya Reply
how to reduced echelon form
Solomon Reply
Jazmine trained for 3 hours on Saturday. She ran 8 miles and then biked 24 miles. Her biking speed is 4 mph faster than her running speed. What is her running speed?
Zack Reply
d=r×t the equation would be 8/r+24/r+4=3 worked out
Sheirtina
Got questions? Join the online conversation and get instant answers!
Jobilize.com Reply

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Object-oriented programming (oop) with java. OpenStax CNX. Jun 29, 2016 Download for free at https://legacy.cnx.org/content/col11441/1.201
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Object-oriented programming (oop) with java' conversation and receive update notifications?

Ask