-
Notifications
You must be signed in to change notification settings - Fork 1.7k
ToConstructorBindings
New in Guice 3.0
Occasionally it's necessary to bind a type to an arbitrary constructor. This
comes up when the @Inject
annotation cannot be applied to the target
constructor: either because it is a third party class, or because multiple
constructors that participate in dependency injection.
@Provides methods provide the best solution to this
problem! By calling your target constructor explicitly, you don't need
reflection and its associated pitfalls. But there are limitations of that
approach: manually constructed instances do not participate in AOP.
To address this, Guice has toConstructor()
bindings. They require you to
reflectively select your target constructor and handle the exception if that
constructor cannot be found:
public class BillingModule extends AbstractModule {
@Override
protected void configure() {
try {
bind(TransactionLog.class).toConstructor(
DatabaseTransactionLog.class.getConstructor(DatabaseConnection.class));
} catch (NoSuchMethodException e) {
addError(e);
}
}
}
In this example, the DatabaseTransactionLog
must have a constructor that takes
a single DatabaseConnection
parameter. That constructor does not need an
@Inject
annotation. Guice will invoke that constructor to satisfy the binding.
Each toConstructor()
binding is scoped independently. If you create multiple
singleton bindings that target the same constructor, each binding yields its own
instance.
-
User's Guide
-
Integration
-
Extensions
-
Internals
-
Releases
-
Community