@Retention(value=RUNTIME) @Target(value={FIELD,METHOD}) public @interface XmlElementWrapper
    //Example: code fragment
      int[] names;
    // XML Serialization Form 1 (Unwrapped collection)
    <names> ... </names>
    <names> ... </names>
    // XML Serialization Form 2 ( Wrapped collection )
    <wrapperElement>
       <names> value-of-item </names>
       <names> value-of-item </names>
       ....
    </wrapperElement>
 
 The two serialized XML forms allow a null collection to be represented either by absence or presence of an element with a nillable attribute.
Usage
The @XmlElementWrapper annotation can be used with the following program elements:
The usage is subject to the following constraints:
XmlElement,
            XmlElements,
            XmlElementRef,
            XmlElementRefs,
            XmlJavaTypeAdapter.See "Package Specification" in javax.xml.bind.package javadoc for additional common information.
XmlElement, 
XmlElements, 
XmlElementRef, 
XmlElementRefs| Modifier and Type | Optional Element | Description | 
|---|---|---|
| String | name | Name of the XML wrapper element. | 
| String | namespace | XML target namespace of the XML wrapper element. | 
| boolean | nillable | If true, the absence of the collection is represented by
 using xsi:nil='true'. | 
| boolean | required | Customize the wrapper element declaration to be required. | 
public abstract String name
public abstract String namespace
If the value is "##default", then the namespace is determined as follows:
XmlSchema annotation,
  and its elementFormDefault
  is QUALIFIED, then the namespace of
  the enclosing class.
  public abstract boolean nillable
public abstract boolean required
If required() is true, then the corresponding generated XML schema element declaration will have minOccurs="1", to indicate that the wrapper element is always expected.
Note that this only affects the schema generation, and not the unmarshalling or marshalling capability. This is simply a mechanism to let users express their application constraints better.
 Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.