Class QName
- All Implemented Interfaces:
Serializable
QName
represents a qualified name
as defined in the XML specifications: XML Schema Part2:
Datatypes specification, Namespaces
in XML.
The value of a QName
contains a Namespace
URI, local part and
prefix.
The prefix is included in QName
to retain lexical
information when present in an XML input source
. The prefix is
NOT used in QName.equals(Object)
or to compute the QName.hashCode()
. Equality and the hash code are defined using
only the Namespace URI and local part.
If not specified, the Namespace URI is set to XMLConstants.NULL_NS_URI
.
If not specified, the prefix is set to XMLConstants.DEFAULT_NS_PREFIX
.
QName
is immutable.
- Since:
- 1.5
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionQName
constructor specifying the local part.QName
constructor specifying the Namespace URI and local part.QName
constructor specifying the Namespace URI, local part and prefix. -
Method Summary
Modifier and TypeMethodDescriptionfinal boolean
Test thisQName
for equality with anotherObject
.Get the local part of thisQName
.Get the Namespace URI of thisQName
.Get the prefix of thisQName
.final int
hashCode()
Generate the hash code for thisQName
.toString()
Returns the string representation of thisQName
.static QName
Returns aQName
from its string representation.
-
Constructor Details
-
QName
QName
constructor specifying the Namespace URI and local part.If the Namespace URI is
null
, it is set toXMLConstants.NULL_NS_URI
. This value represents no explicitly defined Namespace as defined by the Namespaces in XML specification. This action preserves compatible behavior with QName 1.0. Explicitly providing theXMLConstants.NULL_NS_URI
value is the preferred coding style.If the local part is
null
anIllegalArgumentException
is thrown. A local part of "" is allowed to preserve compatible behavior with QName 1.0.When using this constructor, the prefix is set to
XMLConstants.DEFAULT_NS_PREFIX
.The Namespace URI is not validated as a URI reference. The local part is not validated as a NCName as specified in Namespaces in XML.
- Parameters:
namespaceURI
- Namespace URI of theQName
localPart
- local part of theQName
- Throws:
IllegalArgumentException
- WhenlocalPart
isnull
- See Also:
-
QName
QName
constructor specifying the Namespace URI, local part and prefix.If the Namespace URI is
null
, it is set toXMLConstants.NULL_NS_URI
. This value represents no explicitly defined Namespace as defined by the Namespaces in XML specification. This action preserves compatible behavior with QName 1.0. Explicitly providing theXMLConstants.NULL_NS_URI
value is the preferred coding style.If the local part is
null
anIllegalArgumentException
is thrown. A local part of "" is allowed to preserve compatible behavior with QName 1.0.If the prefix is
null
, anIllegalArgumentException
is thrown. UseXMLConstants.DEFAULT_NS_PREFIX
to explicitly indicate that no prefix is present or the prefix is not relevant.The Namespace URI is not validated as a URI reference. The local part and prefix are not validated as a NCName as specified in Namespaces in XML.
- Parameters:
namespaceURI
- Namespace URI of theQName
localPart
- local part of theQName
prefix
- prefix of theQName
- Throws:
IllegalArgumentException
- WhenlocalPart
orprefix
isnull
-
QName
QName
constructor specifying the local part.If the local part is
null
anIllegalArgumentException
is thrown. A local part of "" is allowed to preserve compatible behavior with QName 1.0.When using this constructor, the Namespace URI is set to
XMLConstants.NULL_NS_URI
and the prefix is set toXMLConstants.DEFAULT_NS_PREFIX
.In an XML context, all Element and Attribute names exist in the context of a Namespace. Making this explicit during the construction of a
QName
helps prevent hard to diagnosis XML validity errors. The constructorsQName(String namespaceURI, String localPart)
andQName(String namespaceURI, String localPart, String prefix)
are preferred.The local part is not validated as a NCName as specified in Namespaces in XML.
- Parameters:
localPart
- local part of theQName
- Throws:
IllegalArgumentException
- WhenlocalPart
isnull
- See Also:
-
-
Method Details
-
getNamespaceURI
Get the Namespace URI of this
QName
.- Returns:
- Namespace URI of this
QName
-
getLocalPart
-
getPrefix
Get the prefix of this
QName
.The prefix assigned to a
QName
might NOT be valid in a different context. For example, aQName
may be assigned a prefix in the context of parsing a document but that prefix may be invalid in the context of a different document.- Returns:
- prefix of this
QName
-
equals
Test this
QName
for equality with anotherObject
.If the
Object
to be tested is not aQName
or isnull
, then this method returnsfalse
.Two
QName
s are considered equal if and only if both the Namespace URI and local part are equal. This method usesString.equals()
to check equality of the Namespace URI and local part. The prefix is NOT used to determine equality.This method satisfies the general contract of
Object.equals(Object)
-
hashCode
public final int hashCode()Generate the hash code for this
QName
.The hash code is calculated using both the Namespace URI and the local part of the
QName
. The prefix is NOT used to calculate the hash code.This method satisfies the general contract of
Object.hashCode()
. -
toString
Returns the string representation of thisQName
. The format is:{NamespaceURI}LocalPart
NamespaceURI
isnull
, onlyLocalPart
is returned. -
valueOf
Returns aQName
from its string representation. The string representation must be in the format returned bytoString()
:{NamespaceURI}LocalPart
Prefix
is not represented in the string form, it will be set toXMLConstants.DEFAULT_NS_PREFIX
.- API Note:
- This method does not perform full validation of the resulting
QName
. TheNamespaceURI
is not validated as a URI reference. TheLocalPart
is not validated as a NCName as specified in Namespaces in XML. - Parameters:
qNameAsString
- the string representation of theQName
- Returns:
- a
QName
from its string representation - Throws:
IllegalArgumentException
- ifqNameAsString
isnull
or malformed- See Also:
-