pluggable interface : Java Glossary

*0-9ABCDEFGHIJKLMNOPQRSTUVWXYZ (all)

pluggable interface
Java’s interfaces and dynamic class loading make it easy to create pluggable interfaces such as LAF (Look And Feel), JCE (Java Cryptography Extension) and JDBC (Java Data Base Connectivity). Many vendors can supply different code to implement the same interface that all behaves the same way, and easily plugs into a framework library without requiring any recompilation or linking. One of the clues you are using a pluggable interface is the lack of public constructors. All objects must be created via factory methods. The other clue is nearly all methods return interfaces rather than concrete classes.

To create a pluggable interface you define a suite of interfaces that a vendor or other third party must implement with real classes. He bundles his implementation code into a jar. Typically there will be a special registration class in the jar that gives the names of the class to use to implement any given interface and perhaps some factory classes to create various types of standard object. The registration class might customise the choices based on platform or user specifications.

To use the interface, the user specifies the vendor name whose implementation he wants. From them on he uses factory methods that look up the correct constructors, and via dynamic loading (Class. forName) or reflection call the vendor-specific methods. These methods return objects that the user then manipulates via their standard interface names, not their class names, though in theory you might use abstract class names too. The user is usually never aware of the vendor’s class names, (unless of course he cheats and peeks with Class. toString).


This page is posted
on the web at:

http://mindprod.com/jgloss/pluggableinterface.html

Optional Replicator mirror
of mindprod.com
on local hard disk J:

J:\mindprod\jgloss\pluggableinterface.html
Canadian Mind Products
Please the feedback from other visitors, or your own feedback about the site.
Contact Roedy. Please feel free to link to this page without explicit permission.

IP:[65.110.21.43]
Your face IP:[3.145.18.97]
You are visitor number