@Target(value={METHOD,TYPE,FIELD}) @Retention(value=RUNTIME) @Documented @Scope @Inherited public @interface Dependent
Specifies that a bean belongs to the dependent pseudo-scope.
Beans declared with scope @Dependent
behave differently to beans with other built-in scope types. When a bean is
declared to have scope @Dependent
:
Every invocation of the Context.get(Contextual, CreationalContext)
operation of the
context object for the @Dependent
scope returns a new instance of the given bean.
Every invocation of the Context.get(Contextual)
operation of the context object for the
@Dependent
scope returns a null value.
The @Dependent
scope is always active.
Many instances of beans with scope @Dependent
belong to some other bean or Java EE component class instance and are
called dependent objects.
@Dependent
injected into a field, bean constructor or initializer method is a
dependent object of the bean or Java EE component class instance into which it was injected.@Dependent
injected into a producer method is a dependent object of the
producer method bean instance that is being produced.@Dependent
obtained by direct invocation of an
Instance
is a dependent object of the instance of Instance
.
When the container destroys an instance of a bean or of any Java EE component class supporting injection, the container
destroys all its dependent objects, after the @PreDestroy
callback completes and after the servlet
destroy()
method is called.
Comments to: cdi-dev@eclipse.org.
Copyright © 2018,2020 Eclipse Foundation.
Use is subject to license terms.