It struck me that a difficulty with using interfaces and factories in Java is that you need to know which factory goes with which interface. A naming convention can help here, but it might not be consistent.
Instead, I suggest that you annotate your interface, to know about a default implementation.
This immediately brings up "Interfaces shouldn't be bound to their implementations!!! This is unpure, evil code!!!". When you are navigating code, trying to find implementations for a particular interface can be annoying and time-consuming.
I have set out here the most cohesive way I can think of for finding out which class to use as a default implementation when all you have is an interface. It doesn't 'bind' the implementation to the interface. It neither 'binds' nor mentions the implementation. The interface 'knows about' a factory.
I experimented with non-annotation ways of doing this, such as static blocks in interfaces, xdoclet-based solutions (well, I thought about xdoclet), but I decided they were all ugly. I think what I have is the most elegant but pragmatic way.
Time for some code.
@DefaultFactory(BlobbyFactory.class)
interface Blobby
{
void doSomething();
}
This says that BlobbyFactory is the default factory for the Blobby interface.
So when you want a Blobby, you instantiate BlobbyFactory and call its newInstance method.
As a convenience, I wrote a Farm class that you can use as follows:
Blobby blobby=(Blobby)new Farm().newInstance(Blobby.class);
The reason newInstance is not a static method is that you may wish to override the default factory, in some part of your application.
So the unit testing part of your application might want a mock object instead of whatever BlobbyFactory gives you (actually a BlobbyImplementation in this case).
Farm farm=new Farm();
farm.setFactory(Blobby.class,new MockBlobbyFactory());
then elsewhere:
Blobby blobby=(Blobby)farm.newInstance(Blobby.class);
In effect, a Farm is a Map
General musings on programming languages, and Java.
Saturday, April 09, 2005
A new design pattern (Farm) and a nifty use of annotations.
Posted by Ricky Clarkson at 4:29 pm 5 comments
Wednesday, April 06, 2005
Requirement Orientated Development
For a long time I have thought that most software solutions are too far removed from the problem they attempt to solve. The simple answer seems to be to identify the use cases and base the system around those. However, normal software development seems to move away from the use cases, so I have created a new development model, called Requirement Orientated Development, or ROD, which aims to make the use case part of the code. A system consists of a number of UseCases. Each UseCase has a number of Actions which can take inputs and give outputs, and can do some processing. A UserInterface (e.g., ServletUserInterface, SwingUserInterface, AtmUserInterface, UnitTestUserInterface) works out the possible Actions at any particular time and gives the user those to choose from. I have not yet dealt with use cases which can loop, and branching is done with duplication, so it is still quite naive, but I aim to make this progress. Am I reinventing old concepts, simplifying matters too much, or have I come across something worth following up? Let me know your thoughts. I'll post some code in another blog post sometime.
Posted by Ricky Clarkson at 6:27 pm 2 comments
Blog Archive
- May (1)
- April (1)
- January (1)
- December (1)
- November (1)
- October (1)
- September (3)
- January (2)
- December (1)
- November (1)
- September (3)
- July (2)
- June (2)
- April (1)
- March (1)
- February (1)
- January (2)
- December (2)
- November (1)
- October (5)
- September (1)
- August (2)
- July (1)
- June (5)
- May (4)
- April (2)
- March (4)
- February (3)
- January (1)
- December (3)
- October (2)
- September (1)
- July (1)
- July (1)
- April (2)
- October (1)
About Me
- Ricky Clarkson
- A salsa dancing, DJing programmer from Manchester, England.
My Blog List
-
Error'd: Secret Horror2 days ago
-
Human Altitude2 days ago
-
Telnaes quits The Washington Post2 weeks ago
-
-
There’s no single error rate4 years ago
-
-
Thanks to the Clojure Community!10 years ago
-
-
Debug Mode is the Only Mode12 years ago
-
The Emperor's Garden13 years ago
-
HackWeek V14 years ago
-
-
-