I’m experimenting with using generics to support a configurable structure of delegating objects (decorators, wrappers). I want to build a chain of delegators that implements a target interface as well as a generic delegator interface.
I have this outline:
class Test {
static interface Delegator<T> {}
static class DelegatorChain<T extends Delegator<T>> {}
static interface Foo {}
static class FooDelegator implements Delegator<Foo>, Foo {}
public static void main(String[] args) {
DelegatorChain<FooDelegator> chain = new DelegatorChain<FooDelegator>();
}
}
But, when trying to instantiate the chain variable, compiler complains:
Bound mismatch: The type Test.FooDelegator is not a valid substitute for the bounded parameter
<Tof the type
extends Test.Delegator<T>>Test.DelegatorChain<T>
I admit that generics is like magic to me, but I can somehow acknowledge that FooDelegator is not a Foo that extends Delegator<Foo>, it simply implements both interfaces.
Given that it’s clear what I want to accomplish, is there anything I can do w.r.t. generics to fix it, or am I just better of forgetting about it?
Under your definition, a Delegator is a Delegator of itself (like Comparable is for example), however it seems the intention is that Delegator is a Delegator of a super class. Luckily, generics has a way of expressing this:
This says that the “Delagator type must be a super class of T”. With this change, the rest of your original code compiles:
Also, anytime you use a generic super bound, your code looks really cool 🙂
Note: This following was originally the “first option” in the question.
There is another way to get your code to compile, but it is inferior because it loses the connect between the Delegator type and what it’s delegating from: