1 / 16

Understanding Data Structures Abstraction

Learn how data structures should be abstractions, separating interface from implementation for managing complexity and reusability. Examples of ADTs like Rational and Vector, interfaces, pre- and postconditions, and polymorphism via interfaces.

jcromwell
Download Presentation

Understanding Data Structures Abstraction

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Lecture 8 • Data Structures • Abstraction • The “Structures” package • Preconditions and postconditions • Interfaces • Polymorphism • Vector class • What is a list?

  2. Abstraction • Data structures should be abstractions: • details are hidden • interface separated from implementation • Benefits: • manage complexity • reusability

  3. Abstract Data Types • ADT: • organized collection of information • operations for managing information • The set of operations define the interface to the ADT • As long as the ADT accurately fulfills the promises of the interface, it doesn't really matter how the ADT is implemented • Objects are a perfect programming mechanism to create ADTs because their internal details are encapsulated

  4. Examples of Structures: • Rational: manipulate fractions (LL p196, B p8) • Die, PairOfDice, Card, DeckOfCards…: you know! (LL) • Wordlist: A list of words (I.e., strings) (B p11) • BankAccount: manage account number and value (B p12) • Association: generalization of BankAccount--key/value pair (B 16) • Store: a bunch of things?… (B 18) • int size() • boolean isEmpty() • void clear() • Collection: ? (B19) • Vector: a list, similar to array (part of java.util) (LL p302, B p36) • Matrix: manipulate 2-D arrays as matrices (B p43)

  5. The Collection Interface public interface Collection extends Store { public boolean contains(Object value); // pre: value is non-null // post: returns true iff the collection contains the value public void add(Object value); // pre: value is non-null // post: the value is added to the collection // the replacement policy is not specified. public Object remove(Object value); // pre: value is non-null // post: removes an object "equal" to value within collection. public Iterator elements(); // post: returns an iterator for traversing collection }

  6. Pre- and Postconditions • Precondition: the conditions under which a method may be called and expected to produce correct results • Postcondition: the state of the program once the method has completed, provided the precondition was met • Details - see B. chapter 2

  7. Interfaces • A Java interface is a collection of abstract methods and constants • An abstract method is a method header without a method body • An abstract method can be declared using the modifier abstract, but because all methods in an interface are abstract, it is usually left off • An interface is used to formally define a set of methods that a class will implement

  8. interface is a reserved word A semicolon immediately follows each method header Interfaces None of the methods in an interface are given a definition (body) public interface Doable { public void doThis(); public int doThat(); public void doThis2 (float value, char ch); public boolean doTheOther (int num); }

  9. Interfaces • An interface cannot be instantiated • Methods in an interface have public visibility by default • A class formally implements an interface by • stating so in the class header • providing implementations for each abstract method in the interface • If a class asserts that it implements an interface, it must define all methods in the interface or the compiler will produce errors.

  10. implements is a reserved word Each method listed in Doable is given a definition Interfaces public class CanDo implements Doable { public void doThis () { // whatever } public void doThat () { // whatever } // etc. }

  11. Interfaces • A class that implements an interface can implement other methods as well • See Speaker.java (LL p236) • See Philosopher.java (LL p237) • See Dog.java (LL p238) • A class can implement multiple interfaces • The interfaces are listed in the implements clause, separated by commas • The class must implement all methods in all interfaces listed in the header

  12. Polymorphism via Interfaces • An interface name can be used as the type of an object reference variable Doable obj; • The obj reference can be used to point to any object of any class that implements the Doable interface • The version of doThis that the following line invokes depends on the type of object that obj is referring to: obj.doThis();

  13. Polymorphism via Interfaces • That reference is polymorphic, which can be defined as "having many forms" • That line of code might execute different methods at different times if the object that obj points to changes • See Talking.java (LL p240) • Note that polymorphic references must be resolved at run time; this is called dynamic binding • Careful use of polymorphic references can lead to elegant, robust software designs

  14. Interfaces • The Java standard class library contains many interfaces that are helpful in certain situations • The Comparable interface contains an abstract method called compareTo, which is used to compare two objects • The String class implements Comparable which gives us the ability to put strings in alphabetical order • The Iterator interface contains methods that allow the user to move through a collection of objects easily

  15. The Vector Class • An object of class Vector is similar to an array in that it stores multiple values • However, a vector • stores objects • does not have the indexing syntax that arrays have • has methods that can be used to manipulate elements • size of vector can change (expand) to fit more elements • The Vector class is part of the java.util package • An alternative (equivalent?) implementation is given in Structures package • See Beatles.java(LL p304)

  16. The Vector Class • The Vector class is implemented using an array • Whenever new space is required, a new, larger array is created, and the values are copied from the original to the new array • To insert an element, existing elements are first copied, one by one, to another position in the array • An implementation of Vector and other structures: www.cs.williams.edu/~bailey/JavaStructures/source/index.html

More Related