public abstract class Schema extends Object
This object represents a set of constraints that can be checked/ enforced against an XML document.
 A Schema object is thread safe and applications are
 encouraged to share it across many parsers in many threads.
 
 A Schema object is immutable in the sense that it shouldn't
 change the set of constraints once it is created. In other words,
 if an application validates the same document twice against the same
 Schema, it must always produce the same result.
 
 A Schema object is usually created from SchemaFactory.
 
 Two kinds of validators can be created from a Schema object.
 One is Validator, which provides highly-level validation
 operations that cover typical use cases. The other is
 ValidatorHandler, which works on top of SAX for better
 modularity.
 
 This specification does not refine
 the Object.equals(java.lang.Object) method.
 In other words, if you parse the same schema twice, you may
 still get !schemaA.equals(schemaB).
| Modifier | Constructor | Description | 
|---|---|---|
| protected  | Schema() | Constructor for the derived class. | 
| Modifier and Type | Method | Description | 
|---|---|---|
| abstract Validator | newValidator() | |
| abstract ValidatorHandler | newValidatorHandler() | Creates a new  ValidatorHandlerfor thisSchema. | 
protected Schema()
The constructor does nothing.
public abstract Validator newValidator()
Validator for this Schema.
 A validator enforces/checks the set of constraints this object represents.
Implementors should assure that the properties set on the
 SchemaFactory that created this Schema are also
 set on the Validator constructed.
public abstract ValidatorHandler newValidatorHandler()
ValidatorHandler for this Schema.
 Implementors should assure that the properties set on the
 SchemaFactory that created this Schema are also
 set on the ValidatorHandler constructed.
 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.