Why Use Interface in Java or Object Oriented Programming
Many times, I have seen questions like why should we use interface in Java, if we can not define any concrete methods inside interface? Or even more common, What is the real use of interface in Java? I can understand beginners asking this question, when they just see name of the method inside interface and nothing else. It takes time to realize real goodness or actual use of interface or abstraction in Java or any object oriented programming. One reason of this is lack of experience in really modelling something real in program using object oriented analysis and design. In this article, I will try to answer this question and give you couple of reason to use interface in your code. If you have good understanding of Object oriented basics e.g. Polymorphism, then you know that it allows you to write flexible code. Interface or abstraction are key to achieve polymorphism, when a caller use interface for calling a method, he introduce flexibility and dynamism in code, as that code will work with any implementation of that interface, not just the present concrete implementation. You will never going to get this flexibility, if you use concrete classes for calling methods, we will see this in more details in next section. Also Programming for Interfaces, is also well recognized and one of the key object oriented design principle for coding. Another use of interface in Java is that, it opens new opportunities for other goodies e.g. design patterns. Lot's of design patterns are heavily relied on interfaces and Polymorphism e.g. Decorator, Composite, Proxy or Adapter pattern, all implements same interface, as there target, and because they are based on interfaces, they can be used interchangeably.
If you look closely, you will find that, most of the time we use methods from interface. For example, here we are using get() method from Map interface, you could definitely write following code in terms of HashMap or Hashtable, but then you switched to another implementation e.g. ConcurrentHashMap, you need to change your code. Here, we are using Map interface for getting Employee object from Cache, which can be any valid Map implementation, including HashMap, Hashtable, or ConcurrentHashMap. On similar line, you should use interface as Type of method arguments and as return type. This makes your code flexible enough to operate on any implementation.
That's all on why you should use interface in Java. Though you can not define concrete methods, it's best way to introduce abstraction in your design. Real use of interface is to improve code quality by allowing modules to depend upon higher level of abstraction, which is less likely to change than lower level concrete classes, which is more likely to change. Use of interface also opens opportunities for using tried and tested Java design pattern and immensely helps in Unit testing as well. Most importantly, use of interface will give you different level of thinking and probably it's one step in mastering object oriented analysis and design.
Use Interface for Flexibility and Polymorphism
As I said, polymorphism is powerful and provides flexibility and dynamic behaviour to your code. In order to take use of Polymorphism, you can either use interface or abstract class in Java. Interface provides highest degree of abstraction. For example following code, which is based on interfaces, and an example of programming to interface than implementation principle, is flexible enough to work with any Map implementation in Java.Map cache = CacheFactory.getCach();
Employee emp = cache.get("EmployeeID"); // this line depends upon interface Map, rather than concrete class e.g. HashMap
If you look closely, you will find that, most of the time we use methods from interface. For example, here we are using get() method from Map interface, you could definitely write following code in terms of HashMap or Hashtable, but then you switched to another implementation e.g. ConcurrentHashMap, you need to change your code. Here, we are using Map interface for getting Employee object from Cache, which can be any valid Map implementation, including HashMap, Hashtable, or ConcurrentHashMap. On similar line, you should use interface as Type of method arguments and as return type. This makes your code flexible enough to operate on any implementation.
Use Interface in Java to accommodate Design patterns
If you are familiar of famous GOF design patterns than you know that most of the behavioural pattern use Polymorphism for dynamic behaviour, e.g. Decorator pattern, implements same interface as the object, which it decorates. If you don't use interface, it would be impossible to incorporate design patterns e.g. if your method accept concrete type, rather than abstract type, then you can not pass anything else to them. You not only lose flexibility but also runtime behaviour enrichment. Similarly, Composite pattern also uses same interface as object it contains, and this allows caller to deal with a normal object or composite object in same way, had they don't use interface, it wasn't possible. Proxy and Adapter design pattern also relies on higher level abstraction e.g. interface or abstract class, to provide added behaviour. In short, interface is not just a good coding practice, it also open path to incorporate other best practices in your code.Use Interface to help Unit Testing
Testing is a big concern for any Project. Project Managers, Technical lead and developers will always prefer a code which can be unit tested easily in isolation with other moving parts. When we use interfaces in our code, our method start depending upon interfaces than implementation, which makes unit testing extremely easy. For example, a code which is using Database can not be tested in isolation, until database is available, but if same code is using interface to interact with database layer (DAO design pattern), you can always provide a dummy or mock object to mimic database calls. By using interface in your code, you get flexibility everywhere.That's all on why you should use interface in Java. Though you can not define concrete methods, it's best way to introduce abstraction in your design. Real use of interface is to improve code quality by allowing modules to depend upon higher level of abstraction, which is less likely to change than lower level concrete classes, which is more likely to change. Use of interface also opens opportunities for using tried and tested Java design pattern and immensely helps in Unit testing as well. Most importantly, use of interface will give you different level of thinking and probably it's one step in mastering object oriented analysis and design.
No comments:
Post a Comment