javax.enterprise.context

Annotation Type Dependent


  • @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:

    • No injected instance of the bean is ever shared between multiple injection points.
    • Any instance of the bean injected into an object that is being created by the container is bound to the lifecycle of the newly created object.
    • When a Unified EL expression in a JSF or JSP page that refers to the bean by its EL name is evaluated, at most one instance of the bean is instantiated. This instance exists to service just a single evaluation of the EL expression. It is reused if the bean EL name appears multiple times in the EL expression, but is never reused when the EL expression is evaluated again, or when another EL expression is evaluated.
    • Any instance of the bean that receives a producer method, producer field, disposer method or observer method invocation exists to service that invocation only.
    • Any instance of the bean injected into method parameters of a disposer method or observer method exists to service the method invocation only.

    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.

    • Instances of decorators and interceptors are dependent objects of the bean instance they decorate.
    • An instance of a bean with scope @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.
    • An instance of a bean with scope @Dependent injected into a producer method is a dependent object of the producer method bean instance that is being produced.
    • An instance of a bean with scope @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.

    Author:
    Gavin King, Pete Muir

Document created the 11/06/2005, last modified the 18/08/2025
Source of the printed document:https://www.gaudry.be/en/java-api-javaee-rf-javax/enterprise/context/Dependent.html

The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.

References

  1. View the html document Language of the document:fr Manuel PHP : https://docs.oracle.com, Dependent (Java(TM) EE 7 Specification APIs)

These references and links indicate documents consulted during the writing of this page, or which may provide additional information, but the authors of these sources can not be held responsible for the content of this page.
The author of this site is solely responsible for the way in which the various concepts, and the freedoms that are taken with the reference works, are presented here. Remember that you must cross multiple source information to reduce the risk of errors.