<< Chapter < Page Chapter >> Page >

Collection is an interface

The TreeSet class implements the SortedSet interface, which extends the Set interface, which in turn extends the Collection interface. Thus, a TreeSet object is a Collection . Therefore, a reference to a TreeSet object can be stored in a reference variable of type Collection , and can be treated as the generic type Collection .

What is a TreeSet object?

Among other things, in CS2 courses, we worry about the time and memory cost of a collection. According to Sun, the TreeSet class guarantees that the sorted set will be in ascending element order, and provides guaranteed log(n)time cost for the basic operations ( add , remove and contains ).

What does ascending element order mean?

Again, according to Sun, the elements will be sorted according to the natural order of the elements (see the Comparable interface) or by a comparator (see the Comparator interface) provided at the time the set is created. This depends on which overloaded constructor is used. I will have moreto say about these alternatives in a future module.

What does log(n) time cost mean?

I'm not going to try to explain the details of log(n) time cost here. Suffice it to say that the add , remove , and contains methods execute very fast. (I will have more to say about this is a future module.)

A TreeSet object is a Set

An object of the TreeSet class also is a Set . One of the characteristics of a Java Set (an object that implements the Set interface) is that it can contain no duplicate elements. Therefore, a TreeSet object can contain no duplicate elements. If the add method of a TreeSet object is called in an attempt to add a duplicate element, the element will not be added.

A TreeSet object is a SortedSet

The TreeSet class also implements the SortedSet interface. This guarantees that the contents of a TreeSet object will be in ascending element order, regardless of the order in which the elements are added. (In a future module, I will discuss how comparisons are made to enforce theordering of the elements.)

A TreeSet object is a Collection

Because an object of the TreeSet class is a Collection , a reference to such an object can be passed to any method that requires anincoming parameter of type Collection . The receiving method can call anymethod on that reference that is declared in the Collection interface . (I will discuss such methods in detail in future modules.)

Populate the Collection

The statement in Listing 2 passes the TreeSet object's reference to a method named fillIt , which is a static method of the Populator class. (The Populator class is a class of my own design whose only purpose is to illustrate the polymorphic behavior achieved using the CollectionsFramework.) The behavior of this method is to add elements to the incoming Collection object without regard for the actual type of the object (the class from which the object was instantiated).

Listing 2 . Populate the collection.
Populator.fillIt(ref);

At this point, I am going to discuss the fillIt method of the Populator class called in Listing 2 . The entire class definition of the Populator class, including the fillit method, is shown in Listing 3 .

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