File APIs for Java Developers
Manipulate DOC, XLS, PPT, PDF and many others from your application.
The moose likes Java in General and the fly likes Purpose of Marker Interface Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Java » Java in General
Reply locked New topic

Purpose of Marker Interface

Senthil Kumar Sekar
Ranch Hand

Joined: Aug 08, 2010
Posts: 45

Hi All,
Iam still not cleared with the purpose of Marker Interface inspite of reading many articles.I think one way communiction on this topic will not help me in understanding and so this thread.

Cloneable is a Marker Interface.

When we call clone() on an object - this will throw CloneNotSuppException if the class does not implement Cloneable interface.

So, I need to implement Cloneable - Whats the advantage/benefit/point here.Why not the developer just can call clone() irrespective of not implementing Cloneable interface???

Can anybody explain me here?


Senthil Kumar Sekar

Matthew Brown

Joined: Apr 06, 2010
Posts: 4543

Cloneable and clone() is a bit of a weird design (dating back to the earliest version of Java), so it's probably not a good example of how a marker interface should be used*. But it does demonstrate how they can be used.

A better example is RandomAccess. This is a marker interface used to indicate whether a List can support efficient random access. ArrayList implements RandomAccess, but LinkedList does not. The idea is that an algorithm using a list can check for this (using instanceof), and can use the best approach depending on whether random access is efficient or not.

(* Some would say that nowadays a marker interface should never be used, because annotations are a better solution. They weren't available in the earliest versions of Java).
Winston Gutkowski

Joined: Mar 17, 2011
Posts: 8927

Senthil Kumar Sekar wrote:Iam still not cleared with the purpose of Marker Interface inspite of reading many articles.

To be honest, neither are we; although we all have opinions.

You may be interested in this thread, where I was soundly outvoted...but I'm sticking to my guns (I'm nothing if not stubborn).


Bats fly at night, 'cause they aren't we. And if we tried, we'd hit a tree -- Ogden Nash (or should've been).
Articles by Winston can be found here
I agree. Here's the link:
subject: Purpose of Marker Interface
It's not a secret anymore!