Question

Why Interface??

Asked by: killisrinivas


     What is the need of interface?? when we r not defining any code in the methods in the interface, what purpose does it serve?? we can as well define the methods in the current class(the class which we r implementing the interface), which saves us from overriding all the other methods of the interface - which is another headache.

     im new to Java Programming. i want to have some detailed information and explanation on Interfaces. i know that Intarfaces r used bcoz java doesn't support multiple inheritance. but still what i couldnt get is when there is no code in interface, what is the need for it??

thanking you
with regards,

meena

This Question has been solved and asker verified All Experts Exchange premium technology solutions are available to subscription members.

Subscribe now for full access to Experts Exchange and get

Instant Access to this Solution

  • Plus...
  • 30 Day FREE access, no risk, no obligation
  • Collaborate with the world's top tech experts
  • Unlimited access to our exclusive solution database
  • Never be left without tech help again

Subscribe Now

Asked On
2002-03-07 at 00:18:29ID20274293
Tags

intarfaces

,

interface

,

java

Topic

Java Programming Language

Participating Experts
8
Points
100
Comments
8

Trusted by hundreds of thousands everyday for fast, accurate and reliable tech support.

  • "The time we save is the biggest benefit of Experts Exchange to Warner Bros. What could take multiple guys 2 hours or more each to find is accessed in around 15 minutes on Experts Exchange." Mike Kapnisakis, Warner Bros.
  • "Our team likes having a resource that is more secure than just using Google and most experts using this service really know their stuff. It's nice to look here first versus using Google." Dayna Sellner, Lockheed Martin
  • "Anytime that I've been stumped with a problem, 9 out of 10 times Experts Exchange has either the accepted solution or an open discussion of the potential solution to the problem." Kenny Red, eBay Inc.

See what Experts Exchange can do for you.

Got a question?

We've got the answer.

Experts Exchange has been collecting answers to technology questions since 1996…3 million and counting! If you have a question, chances are we already have your answer.

Screenshot of Experts Exchange Knowledgebase

Need individual assistance?

Our experts are ready to help.

If you can't find the exact answer you're looking for, ask our exclusive community of 50,000 experts. You’ll get a personalized answer from a trusted professional.

Screenshot of Experts Exchange Knowledgebase

Want to learn from the best?

Read articles from industry experts.

Thousands of free tech tips, tricks, how-to’s and tutorials are available in our peer reviewed articles section. See for yourself how smart our experts are, no login required.

Screenshot of an Article

Working on a long term project?

Store your work and research.

Save solutions to your questions, answers you’ve discovered through searching plus helpful articles in your personal knowledgebase for easy future access.

Screenshot of Experts Exchange Knowledgebase

Access the answers to your technology questions today.

Subscribe Now

30-day free trial. Register in 60 seconds.

What Makes Experts Exchange Unique?

Members of the expert community talk about why the experience at Experts Exchange is different than what you will find anywhere else.

Trusted by the world's most respected brands.

image of each brand's logo

Faithfully serving IT professionals since 1996.

Experts Exchange Logo

Try it out and discover for yourself.

Subscribe Now

30-day free trial. Register in 60 seconds.

Related Solutions

  1. For understanding : inherited without override ?
    An easy question just to understand more about Delphi: If a define a destructor as : interface Type TBlabla....... constructor create(AOwner: TComponent); override; destructor destroy; ....... implementation destructor Blabla.destroy; begin Som...
  2. Selecting interfaces for multiple inheritance
    HI! Why java has selected interface for multiple inheritance..Instead with classes.What's the reason behind selecting interfaces for multiple inheritance.In C++ it has been successfully proved multiple inheritance by useing classes.What's the problem java is facing for not...

Free Tech Articles

  1. WARNING: 5 Reasons why you should NEVER fix a computer for free.
    It is in our nature to love the puzzle. We are obsessed. The lot of us. We love puzzles. We love the challenge. We thrive on finding the answer. We hate disarray. It bothers us deep in our soul. W...
  2. SCCM OSD Basic troubleshooting
    SCCM 2007 OSD is a fantastic way to deploy operating systems, however, like most things SCCM issues can sometimes be difficult to resolve due to the sheer volume of logs to sift through and the dispe...
  3. Migrate Small Business Server 2003 to Exchange 2010 and Windows 2008 R2
    This guide is intended to provide step by step instructions on how to migrate from Small Business Server 2003 to Windows 2008 R2 with Exchange 2010. For this migration to work you will need the fo...
  4. Create a Win7 Gadget
    This article shows you how to create a simple "Gadget" -- a sort of mini-application supported by Windows 7 and Vista. Gadgets can be dropped anywhere on the desktop to provide instant information, ...
  5. Outlook continually prompting for username and password
    There have been a lot of questions recently regarding Outlook prompting for a username and password whilst using Exchange 2007. There are a few reasons why this would happen and I will try to cover t...
  6. Backup Exchange 2010 Information Store using Windows Backup
    There seems to be quite a lot of confusion around the ability to backup Exchange 2010 using the built in Windows Backup feature. This stems from the omission of this feature prior to Exchange 2007 s...

Cloud Class Webinars

  1. Avoiding Bugs in Microsoft Access
    Alison Balter takes and in-depth look at avoiding bugs in Access. In this webinar you will learn about using the immediate window to debug your applications, invoking the debugger, using breakpoints to troubleshoot, stepping through code, setting the next statement to execute, ...
  2. Top 10 Best New Features in Visio 2010
    Scott Helmers gives live demonstrations of the top 10 new features in Visio 2010. This webinar will teach you how to create compelling diagrams by adding shapes to the page with a single click, linking the shapes in a diagram to data in Excel (or SQL Server, or SharePoint), ...
  3. IT Consultant Business Secrets Revealed
    Michael Munger, Experts Exchange tech pro and IT consultant, pulls back the curtain on his very successful businesses and answers question on every IT consultant and business owner should know about. He shares secrets on what he did to solve the 5 most common problems in IT, ...
  4. Disaster Recovery and Business Continuity
    Quest CTO, Mike Billon, gives an overview of the steps involved in building a dunamic disaster recovery plan. Through case studies and an examination of software/hardware tooles for monitoring and testing, you'll gain a better understandin of where you are, where you want ...
  5. Organize Your Visio Diagrams with Containers and Lists
    Scott Helmers uses cross functional flowcharts, wireframe diagrams, data graphic legends and seating charts to teach you: how to ustilize all three new structured diagram components in Visio 2010, the best practices for organizeing shapes in previous version of Visio, how to organize ...
  6. How to Us Objects, Properties, Events and Methods in Microsoft Access
    Alison Dalter gives an in-depbth look at objects, properties, events and methods in Microsoft Access. In this webinar you will learn about using the object browser, referring to objects, working with properties and methods, working with object variables, understanding the ...

Join the Community

Give a Little. Get a Lot.

Join the community of experts here and help other tech pros by answering question in your area of expertise. You can earn FREE access to all Experts Exchange's premium features and resources.

Join the Community

Answers

 

by: m_onkey_boyPosted on 2002-03-07 at 00:51:12ID: 6846682

The interface is a contract between classes implementing the inteface and the client that uses them.

Here's an example:

Let's say that your application communicates with another server via XML transactions.  You could write a class called XMLCommunicator that does this communication, and that works fine.  Now suppose you add another server to your network that communicates with some sort of binary stream.  You have to code another class to do this, say you call it BinaryCommunicator.  This works, but now you have to re-code your main application to instantiate the correct class based on which server you want to talk to.  Putting this logic in your main application is bad from a OO point of view, as well as a maintenance point of view.

A better solution would be to define an interface called Communicator with a single method called send().  Your XMLCommunicator and BinaryCommunicator both implement this interface.  Now you can write a class called CommunicatorManager that has a method called getCommunicator(int nType).  Here's how it looks:

public interface Communicator {
public void send();
}

public class CommunicatorManager {
public static final int XML = 0;
public static final int BINARY = 1;
public static Communicator getCommunicator (int nType) {
return (nType == XML) ? new XMLCommunicator() : new BinaryCommunicator();
}
}

public class MainApp {
public static void main (String[] args) {
Communicator c = CommunicatorManager.getCommunicator(Integer.parseInt(args[0]));
c.send();
}
}

-------------------------------------------------

This model abstracts your sending logic from your main application.  To add more Communicators, all you have to do is implement the send() methos and add a few lines of code to CommunicatorManager without having to touch your main application.  This hides how the message is sent from the main app, so it can keep it;s code clean.
----------------------------------------------------

The JDBC classes are a good example of interfaces at work.  You can connect to mysql or sqlserver by changing two lines of code somewhere in your application to switch from one database to another, provided you have the JDBC implementations for each database.  These databases behave entirely different, but your code doesn't need to know this because it is hidden behind the interfaces.

 

by: tomboshellPosted on 2002-03-07 at 00:58:49ID: 6846691

It is a promise of code.  Doesn't that just sound horrible.  When I first heard that I was about to promise the book a lighter.  But you have to work with it to really understand it.

Lest say you define an Interface that promises roughly 10 methods.  Basically some getting and setting methods.  Then you implement that interface in different classes.  Class A works with a Database.  Class B works with .txt data.  Class C is a GUI class.  Class D is something else (work with me here, I am streching my imagination as it is..).

So basically class A would look like:  public class A implements myInter{.....}  and all the other ones would be somewhat similar.  (sure maybe some extends and further implements, but you get the idea.)  

Now suppose you are in class C somewhere and you want to use an instance of the interface?  What?  It is an interface we can't do that!  Yes we can.  All that is needed is to return one of the implementing classes as an instance of that interface.  So in effect class C can access class A but call it the inteface name.  And if you happen to be anticipating dynamic events that could work to your advantage.  ie a method in Class T that has the interface as a parameter.  Then classes A,B,or C could be passed in.  The methods available would only be those defined in the Interface, but with good planning those would be anticipated.

How is that for some good ol' rambling?

Tom

 

by: s_laviePosted on 2002-03-07 at 02:20:11ID: 6846849

It also enables you to use "multiple" inheritance, which the java language preventing. You can extends only one class, but you can implements as many interfaces as you need.

 

by: saxabooPosted on 2002-03-07 at 03:12:50ID: 6846937

Reading s_lavie's comment, you might wonder why Java designers chose to prohibit multiple inheritance (you cannot inherit from multiple classes as s_lavie said), but allowed multiple interface implementation instead.
Indeed, after all an interface can be seen as "an abstract class with abstract methods only and no attributes"

My guess is that those guys were C++ programmers who got tired of tracking bugs in C++ code using mutiple inheritance.

Let me give you an example :

public class HumanBeing
{
  public String fullName;
}

public class Man extends HumanBeing
{
  ...
  public boolean lovesBeerAndSoccer(){return true;}
}

public class Brit extends HumanBeing
{
  public boolean lovesRugbyAndJelly(){return true;}
}

Now what if you want a BritMale class ? Suppose you could write something like :

public class BritMale extends Brit,Man{...}

Wouldn't there be a problem with the "fullName" attribute, both inherited from Man and Brit classes ?
Yes there would be, so C++ introduced the idea of virtual inheritance. Let's stop here on details, the key point is that virtual inheritance is "bad" because it's :
- difficult to learn and code
- error-prone

Rather than trying to find an easy and clean way to do multiple class inheritance, Java designers stated that attributes wouldn't be inherited anyway, and they probably had a lot of pretty good reasons to do so.
Which, I hope, clarifies the interfaces vs. abstract classes debate.

FYI a rumor says that MS C# will bring multiple inheritance back onto the dancefloor in a future version.

-S

 

by: Lab_RatPosted on 2002-03-08 at 05:12:20ID: 6850233



Interfaces are also usefull for doing 'call back' functions, something normally found in games programming and various other system activities.

Imagine you have two classes,

Class A, and Class B.

Class A could be a game, and class B could be the keyboard controller for the game, that would scan all the keys, and send a message back to its instatiator to say when a direction or the fire key is pressed.

It's Class A's job to instantiate B such as:

public class A
  {
  B b;

  public A
    {
    b=new B();
    }

  }

Now imagine B does some stuff, for example trapping keyboard events, it looks at the key, and if it is q,a,o,p or space, it's job is to send a message to its parent class, in this case A.

Ok, at this point you ask yourself, How?

How can the B class access anything inside A?
The answer is not directly and not easilly if you dont use interfaces.

The solution using interfaces would be to have an interface containing the name of a call back function, such as 'sendMessage()'

Class A would then implement sendMessage() togeather with an instance of class B that 'knew' the existence of A.


public class A implements Message
  {
  B b;

  public void sendMessage(String s)
    {
    System.err.println(s);
    }

  public A
    {
    b=new B(this);
    }

  }

and the B class would then use an interface variable that could hold a reference to the parent class.

public class B
  {
  Message callingObjectRef;

  public B(Message callingObject)
    {
    callingObjectRef=callingObject;
    }

  public void sendAMessage(String a)
    {
    callingObjectRef.sendMessage("TESTING!");
    }
  }

Class B remembers the reference to it's parent class, by using the interface name instead of the class name. This means that ANY class can instantiate the B class, and the B class can always call the expected interface method.


An example of the technique can be found found here:

http://skyscraper.fortunecity.com/solarcity/440/demo/demo.html

 

by: MoondancerPosted on 2002-04-22 at 16:21:14ID: 6961452

ADMINISTRATION WILL BE CONTACTING YOU SHORTLY.  Moderators Computer101 or Netminder will return to finalize these if they are still open in 14 days.  Please post closing recommendations before that time.

Below are your open questions as of today.  Questions which have been inactive for 21 days or longer are considered to be abandoned and for those, your options are:
1. Accept a Comment As Answer (use the button next to the Expert's name).
2. Close the question if the information was not useful to you, but may help others. You must tell the participants why you wish to do this, and allow for Expert response.  This choice will include a refund to you, and will move this question to our PAQ (Previously Asked Question) database.  If you found information outside this question thread, please add it.
3. Ask Community Support to help split points between participating experts, or just comment here with details and we'll respond with the process.
4. Delete the question (if it has no potential value for others).
   --> Post comments for expert of your intention to delete and why
   --> YOU CANNOT DELETE A QUESTION with comments; special handling by a Moderator is required.

For special handling needs, please post a zero point question in the link below and include the URL (question QID/link) that it regards with details.
http://www.experts-exchange.com/jsp/qList.jsp?ta=commspt
 
Please click this link for Help Desk, Guidelines/Member Agreement and the Question/Answer process.  http://www.experts-exchange.com/jsp/cmtyHelpDesk.jsp

Click you Member Profile to view your question history and please keep them updated. If you are a KnowledgePro user, use the Power Search option to find them.  

Questions which are LOCKED with a Proposed Answer but do not help you, should be rejected with comments added.  When you grade the question less than an A, please comment as to why.  This helps all involved, as well as others who may access this item in the future.  PLEASE DO NOT AWARD POINTS TO ME.

To view your open questions, please click the following link(s) and keep them all current with updates.
http://www.experts-exchange.com/questions/Q.20222663.html
http://www.experts-exchange.com/questions/Q.20274293.html
http://www.experts-exchange.com/questions/Q.20283706.html


To view your locked questions, please click the following link(s) and evaluate the proposed answer.
http://www.experts-exchange.com/questions/Q.20033735.html
http://www.experts-exchange.com/questions/Q.20096949.html
http://www.experts-exchange.com/questions/Q.20113412.html

*****  E X P E R T S    P L E A S E  ******  Leave your closing recommendations if this item remains inactive another seven (7) days.  If you are interested in the cleanup effort, please click this link http://www.experts-exchange.com/jsp/qManageQuestion.jsp?ta=commspt&qid=20274643
POINTS FOR EXPERTS awaiting comments are listed here -> http://www.experts-exchange.com/commspt/Q.20277028.html
 
Moderators will finalize this question if in @14 days Asker has not responded.  This will be moved to the PAQ (Previously Asked Questions) at zero points, deleted or awarded.
 
Thank you everyone.
 
Moondancer
Moderator @ Experts Exchange

 

by: Venci75Posted on 2003-02-07 at 03:50:31ID: 7902255

No comment has been added lately, so it's time to clean up this TA.
I will leave a recommendation in the Cleanup topic area that this question is:
Answered by: m_onkey_boy
Please leave any comments here within the next seven days.
 
PLEASE DO NOT ACCEPT THIS COMMENT AS AN ANSWER!
 
Venci75
EE Cleanup Volunteer

 

by: NetminderPosted on 2003-02-16 at 17:23:58ID: 7962822

Per recommendation, force-accepted.

Netminder
EE Admin

20120131-EE-VQP-002

3 Ways to Join

30-Day Free Trial

The Experts

98% positive feedback on 31,087 answers since March 2000. angeliii is a Microsoft Most Valuable Professional for his work with MS SQL Server & Develoment.

He has also proven his knowledge of Visual Basic Programming, PHP Scripting and Oracle Databases.

The Experts

97% positive feedback on 10,752 answers since July 2000. lrmoore has more than 18 years experience in the networking industry.

The six-time Mircosoft MVPs specialties include firewalls, virtual private networking, and network management.

Testimonials

"...and excellent source for support... Kind of like having your very own IT dept." Electriciansnet

Testimonials

"I was apprehensive at signing up at first. However... it has already made my life as an IT administrator much easier." JaCrews

Testimonials

"WOW! You guys have great, active, and knowledgeable people on here." moore50

Business Clients

Business Clients

In the Press

"If you’ve got a question... Experts Exchange can supply an answer.”

In the Press

"...an invaluable aid for both IT professionals and those who require tech support."

In the Press

"where IT professionals provide quick answers on just about any topic"

Business Account Plans

Loading Advertisement...