An Interface Is a Collection of Constants and Abstract Methods

An Interface Is a Collection of Constants and Abstract Methods

<p> Interfaces</p><p>An interface is a collection of constants and abstract methods.</p><p>An abstract method has a signature/prototype but no implementation.</p><p>Example: public interface Speaker { public void speak(); public void announce(String str); }</p><p>A class can implement an interface. The requirement for a class to do so is that it provides definitions for each abstract method in the interface. Note that the class can have extra methods not listed in the interface.</p><p>Here is an example: public class Philosopher implements Speaker {</p><p> public String philosophy;</p><p> public Philospher(String thoughts) { philosophy = thoughts; }</p><p> public void speak() { System.out.println(philosophy); } public void announce(String announcement) { System.out.println(announcement); }</p><p> public void pontificate() { for (int i=0; i<5; i++) System.out.println(philosophy); } }</p><p>Thus, you MAY instantiate a Philosopher object after this code is written, but not a Speaker object. (You CAN however use a Speaker reference!!!) Also, multiple classes can implement the same interface and one class can implement multiple interfaces (e.g. public class Philosopher implements Speaker, Student).</p><p>Interfaces allow for polymorphism:</p><p>Imagine a class Dog as follows: public class Dog implements Speaker { ... }</p><p>Now we can declare a Speaker reference, which can both reference a Dog and a Philosopher object:</p><p>Speaker current; current = new Dog(); current.speak(); current = new Philosopher("I think, I think?"); current.speak(); ((Philosopher)current).pontificate();</p><p>Since pontificate is NOT in the speaker interface, a cast must be used before it can be called on the object current references. Note on Polymorphism</p><p>Keep in miund that polymorphism is possible through dynamic binding. The decision of which speak() to call is made a run- time and not compile time. This is less efficient than a static binding (made at compile time), but allows for extra flexibility, so it's worth it.</p><p>You can also make use of polymorphism by passing a parameter into a method: public void sayIt(Speaker current) { current.speak(); }</p><p>Java has a couple of common predefined interfaces: Comparable and Iterator. These are both discussed in the text. Abstract Classes</p><p>These are similar to interfaces, but CAN define methods and variables. However, typically some of the methods are left to be abstract. Also, you can NOT instantiate an object of an abstract class. (This is also true of an interface!!!)</p><p>Here is an example: public abstract class Vehicle }</p><p> protected String maker; protected String model; protected double insurance;</p><p> public Vehicle(String mak, String mod, double ins) { maker = mak; model = mod; insurance = ins; }</p><p> public String toString() { return maker + " " + model; }</p><p> public abstract drive(); }</p><p>Any class that inherits from Vehicle MUST define the method drive().</p>

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    4 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us