Class ManagedList<E>

java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractList<E>
java.util.ArrayList<E>
org.springframework.beans.factory.support.ManagedList<E>
Type Parameters:
E - the element type
All Implemented Interfaces:
Serializable, Cloneable, Iterable<E>, Collection<E>, List<E>, RandomAccess, BeanMetadataElement, Mergeable
Direct Known Subclasses:
ManagedArray

public class ManagedList<E> extends ArrayList<E> implements Mergeable, BeanMetadataElement
Tag collection class used to hold managed List elements, which may include runtime bean references (to be resolved into bean objects).
Since:
27.05.2003
Author:
Rod Johnson, Rob Harrop, Juergen Hoeller, Stephane Nicoll, Sam Brannen
See Also:
  • Constructor Details

    • ManagedList

      public ManagedList()
    • ManagedList

      public ManagedList(int initialCapacity)
  • Method Details

    • of

      @SafeVarargs public static <E> ManagedList<E> of(E... elements)
      Create a new instance containing an arbitrary number of elements.
      Type Parameters:
      E - the List's element type
      Parameters:
      elements - the elements to be contained in the list
      Returns:
      a ManagedList containing the specified elements
      Since:
      5.3.16
    • setSource

      public void setSource(@Nullable Object source)
      Set the configuration source Object for this metadata element.

      The exact type of the object will depend on the configuration mechanism used.

    • getSource

      @Nullable public Object getSource()
      Description copied from interface: BeanMetadataElement
      Return the configuration source Object for this metadata element (may be null).
      Specified by:
      getSource in interface BeanMetadataElement
    • setElementTypeName

      public void setElementTypeName(String elementTypeName)
      Set the default element type name (class name) to be used for this list.
    • getElementTypeName

      @Nullable public String getElementTypeName()
      Return the default element type name (class name) to be used for this list.
    • setMergeEnabled

      public void setMergeEnabled(boolean mergeEnabled)
      Set whether merging should be enabled for this collection, in case of a 'parent' collection value being present.
    • isMergeEnabled

      public boolean isMergeEnabled()
      Description copied from interface: Mergeable
      Is merging enabled for this particular instance?
      Specified by:
      isMergeEnabled in interface Mergeable
    • merge

      public List<E> merge(@Nullable Object parent)
      Description copied from interface: Mergeable
      Merge the current value set with that of the supplied object.

      The supplied object is considered the parent, and values in the callee's value set must override those of the supplied object.

      Specified by:
      merge in interface Mergeable
      Parameters:
      parent - the object to merge with
      Returns:
      the result of the merge operation