Skip to main content

Why Marker Interface Does Not Have Method Declarations?

Every Java programmer knows that Marker Interface does not have any methods in it. Some of you confused if there are no any method declarations, and then what is the use of Marker Interface or Tagged Interface. But very few people know why we use Marker Interface and its use in our programs.

Whenever any class implementing some Marker Interface, just we are telling to JVM to do that particular functionality of interface. So JVM checks that class or it's super class is implementing the Serializable interface or not. That means serialization process is taken care by JVM itself. So you no need to write any code for serialization. Then what is the use of method declarations in Serializable interface when JVM is going to do everything for us.


So, by implementing Serializable interface we are telling to JVM that the object of the class can be seriliazable and do the rest of thing.

Example 1: For instance take Serializable interface. We know that to make an object serializable that class or its super class MUST implenet Serializable Marker Inetrafce. If we are serializing the object,..it means we are telling to JVM to serialize the object. So JVM checks that class or it's super class is implementing the Serializable interface. That means serialization activity is taken care by JVM itself. So you no need to write any code for serialization. Then what is the use of method declarations in Serializable interface when JVM is going to do everything for us.

Example 2: Cloneable Interafce. This interface is implemented by the JVM itself and allows copies of objects to be created. This means developer does not need to write any code to clone the object.
Hence Marker Interfaces are used to enable the capability of a class as implementing a specific interface at run-time.

Hope my understanding is correct and if anyone of you know more about it please write about on Marker Interface in comments section. Thanks in advance.

Comments

Popular posts from this blog

WebSphere MQ Interview Questions

What is MQ and what does it do? Ans. MQ stands for MESSAGE QUEUEING. WebSphere MQ allows application programs to use message queuing to participate in message-driven processing. Application programs can communicate across different platforms by using the appropriate message queuing software products. What is Message driven process? Ans . When messages arrive on a queue, they can automatically start an application using triggering. If necessary, the applications can be stopped when the message (or messages) have been processed. What are advantages of the MQ? Ans. 1. Integration. 2. Asynchrony 3. Assured Delivery 4. Scalability. How does it support the Integration? Ans. Because the MQ is independent of the Operating System you use i.e. it may be Windows, Solaris,AIX.It is independent of the protocol (i.e. TCP/IP, LU6.2, SNA, NetBIOS, UDP).It is not required that both the sender and receiver should be running on the same platform What is Asynchrony? Ans. With messag...

Asynchronous Vs. Synchronous Communications

Synchronous (One thread):   1 thread -> |<---A---->||<----B---------->||<------C----->| Synchronous (multi-threaded):   thread A -> |<---A---->| \ thread B ------------> ->|<----B---------->| \ thread C ----------------------------------> ->|<------C----->|

Advantages & Disadvantages of Synchronous / Asynchronous Communications?

  Asynchronous Communication Advantages: Requests need not be targeted to specific server. Service need not be available when request is made. No blocking, so resources could be freed.  Could use connectionless protocol Disadvantages: Response times are unpredictable. Error handling usually more complex.  Usually requires connection-oriented protocol.  Harder to design apps Synchronous Communication Advantages: Easy to program Outcome is known immediately  Error recovery easier (usually)  Better real-time response (usually) Disadvantages: Service must be up and ready. Requestor blocks, held resources are “tied up”.  Usually requires connection-oriented protocol