Home | Contact Us | FAQ | Search & Site Map | Link to Us
Sign In | Join | Other 45 Sites in Network
HomeAnnouncementsWhite Papers
Discussion GroupsFirst AidDatabasesJavaBeansGUIJava 3DVirtual MachineCORBASecurityToolsGeneral
Java DirectoryOpen Source ProjectsSample Book ChaptersUser GroupsWeb Resources
Related Topics
Databases.NETMore Topics ...

Java Forum / General / July 2007

Tip: Looking for answers? Try searching our database.

Extending an enum

Thread view: 
Roedy Green - 16 Jul 2007 12:54 GMT
You can't extend an enum to either add more enum constants or more
static methods or more instance methods on the enum constants, or more
instance datafields on each enum constant.

Any thoughts on how to fake various types of extensions?
.

Signature

Roedy Green Canadian Mind Products
The Java Glossary
http://mindprod.com

Ingo R. Homann - 16 Jul 2007 13:26 GMT
Hi Roedy,

> You can't extend an enum to either
> Any thoughts on how to fake various types of extensions?

My ideas:

> (1) add more enum constants or

Use a simple class instead of an enum:

class Color {
  static final Color red=new Color(255,0,0);
}

class Color2 {
  static final Color pink=new Color(255,200,200);
}

BTW: I suppose you know the reason, *why* sun decided to make enums not
extendable!?

> (2) more static methods or

I think there is no necessity to do so. Of course, it might have been
"nicer" to write "String content=File.read(...);" instead of "String
content=MyUtilFileClass.read(...);", but I think it is not really that
important.

> (3) more instance methods on the enum constants

No possibility. You cannot even do that with classes, because you simply
cannot convert an Object of type "MySuperClass" to an Object of
"MySubClass". Of course, you may use static helper classes, but I think
you do not want to hear this! ;-)

> (4) more instance datafields on each enum constant.

Same as (3): Because Java has a very statical type system and an Object
(for clarification: in contrast to a reference) can never change its
type! Of course, you may use a (Weak)HashMap to "append" new attributes
to some Objects, but this is no clean solution, IMHO. Another
possibility is to "wrap" your Objects in new Objects which have the
required attributes.

Ciao,
Ingo
Roedy Green - 16 Jul 2007 14:49 GMT
On Mon, 16 Jul 2007 11:54:41 GMT, Roedy Green
<see_website@mindprod.com.invalid> wrote, quoted or indirectly quoted
someone who said :

>You can't extend an enum to either add more enum constants or more
>static methods or more instance methods on the enum constants, or more
>instance datafields on each enum constant.

Why would I want to do such a thing?  In this case I am working on the
Replicator which has two halves  the applet that runs at the client
and the sender than runs on my machine.  I wanted to keep the client
code as small as possible.

So wanted to have a core enum class, and extend it with extra methods
on each enum constant only used by the receiver and ditto for the
sender.

I did not want to repeat code since it would not stay in sync.  So
what I did was a bit ugly but it works.

I passed an enum constant of the common enum class to the
corresponding enum constructor on the extending class.  Then I wrote
wrapper methods to let the extending class present the common methods.
Signature

Roedy Green Canadian Mind Products
The Java Glossary
http://mindprod.com

Daniel Pitts - 16 Jul 2007 21:01 GMT
On Jul 16, 6:49 am, Roedy Green <see_webs...@mindprod.com.invalid>
wrote:
> On Mon, 16 Jul 2007 11:54:41 GMT, Roedy Green
> <see_webs...@mindprod.com.invalid> wrote, quoted or indirectly quoted
[quoted text clipped - 22 lines]
> Roedy Green Canadian Mind Products
> The Java Glossaryhttp://mindprod.com

Perhaps "enum" isn't the right construct for you.  Perhaps an
extensible type token is what you're looking for?
Roedy Green - 16 Jul 2007 21:41 GMT
On Mon, 16 Jul 2007 13:01:15 -0700, Daniel Pitts
<googlegroupie@coloraura.com> wrote, quoted or indirectly quoted
someone who said :

>Perhaps "enum" isn't the right construct for you.  Perhaps an
>extensible type token is what you're looking for?

I think you are right. I started with an enum solution based on ints.
By the time I was done I had no more switches, so that got rid of the
#1 attraction of enum.
Signature

Roedy Green Canadian Mind Products
The Java Glossary
http://mindprod.com



Free Magazines

Get these publications absolutely FREE for up to 12 months. There are no hidden fees and no obligation. Simply choose a title, complete the application form and submit it. Read more ...

Oracle MagazineNetwork ComputingComputer WorldBio-IT WorldeWeekInformation WeekInfosecurity
 
Sign In
Join
My Latest Posts
My Monitored Threads
My Blog
My Photo Gallery
My Profile
My Homepage

Start New Thread
Enable EMail Alerts
Rate this Thread



©2009 Advenet LLC   Privacy Policy - Terms of Use
This website includes both content owned or controlled by Advenet as well as content owned or controlled by third parties.