I have the following class (in JEE, can be made similarly in Spring):
@Singleton
public class MyUnknownPatternClass {
@Inject @Any Instance<SomeInterface> instances;
public SomeInterface getMatchingInstance(Object someDiscriminator) {
for(SomeInterface instance : instances) {
if(instance.supports(someDiscriminator)) {
return instance;
}
}
throw new IllegalArgumentException("Could not find a matching instace for " + someDiscriminator.toString());
}
}
Using dependency injection's discovery to locate all instances of the matching interface, this allows me to totally decouple strategies and the code using it.
For example, with a travelling salesman application, and I'm having different TransportProvider
s which implement a travel(Location l)
method, my business logic can then focus on following regular flow:
Salesman m =...;
Location l = m.getStartLocation();
TransportProvider t = myUnknownPatternClass.getMatchingInstance(m.getTravelMethod());
for(Location d : m.getDestinationsToVisit())
l = t.travel(d);
m.doBusinessHere(l);
}
Thus decoupling whether the salesman travels by foot, boat, car, or any other method.
My understanding is that a factory actually instantiates objects. A servicelocator is more generic, and allows for runtime registration, and the above code seems to do neither. It is not a whiteboard pattern, as it only returns a single instance.
However, it's a very useful pattern, and it would be nice to talk about it properly.
What, then, is it?
And what would then be a proper name for the class
(i.e. SomeInterfaceLocator
, or SomeInterfaceFactory
)?
Edit:
I found this https://en.wikipedia.org/wiki/Command_pattern#Java_8
Is it a command factory pattern?
I think I'll go with (Strategy)Selector
as a pattern. It's not 100 official, but that's what it does.
Unless someone finds a better name, it's to show that it's not a servicelocator, it's not a factory, not a command pattern.