Class MemValueFactory
- java.lang.Object
-
- org.eclipse.rdf4j.model.base.AbstractValueFactory
-
- org.eclipse.rdf4j.sail.memory.model.MemValueFactory
-
- All Implemented Interfaces:
ValueFactory
public class MemValueFactory extends AbstractValueFactory
A factory for MemValue objects that keeps track of created objects to prevent the creation of duplicate objects, minimizing memory usage as a result.- Author:
- Arjohn Kampman, David Huynh
-
-
Constructor Summary
Constructors Constructor Description MemValueFactory()A cache of the most common IRIs to improve lookup performance when users use our vocabularies (eg.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidclear()BNodecreateBNode(String nodeID)Creates a new blank node with the given node identifier.IRIcreateIRI(String uri)Creates a new IRI from the supplied string-representation.IRIcreateIRI(String namespace, String localName)Creates a new IRI from the supplied namespace and local name.LiteralcreateLiteral(boolean value)Creates a new xsd:boolean-typed literal representing the specified value.LiteralcreateLiteral(String value)Creates a new literal with the supplied label.LiteralcreateLiteral(String value, String language)Creates a new literal with the supplied label and language attribute.LiteralcreateLiteral(String value, CoreDatatype datatype)Creates a new literal with the supplied label and datatype.LiteralcreateLiteral(String value, IRI datatype)Creates a new literal with the supplied label and datatype.LiteralcreateLiteral(XMLGregorianCalendar calendar)Creates a new literal representing the specified calendar that is typed using the appropriate XML Schema date/time datatype.MemBNodegetMemBNode(BNode bnode)See getMemValue() for description.Set<MemBNode>getMemBNodes()Deprecated, for removal: This API element is subject to removal in a future version.Use getMemBNodesIterator() instead.WeakObjectRegistry.AutoCloseableIterator<MemBNode>getMemBNodesIterator()Gets all bnodes that are managed by this value factory.WeakObjectRegistry.AutoCloseableIterator<MemIRI>getMemIRIsIterator()Gets all URIs that are managed by this value factory.MemLiteralgetMemLiteral(Literal literal)See getMemValue() for description.Set<MemLiteral>getMemLiterals()Deprecated, for removal: This API element is subject to removal in a future version.Use getMemLiteralsIterator() instead.WeakObjectRegistry.AutoCloseableIterator<MemLiteral>getMemLiteralsIterator()Gets all literals that are managed by this value factory.MemResourcegetMemResource(Resource resource)See getMemValue() for description.MemIRIgetMemURI(IRI uri)See getMemValue() for description.Set<MemIRI>getMemURIs()Deprecated, for removal: This API element is subject to removal in a future version.Use getMemIRIsIterator() instead.MemValuegetMemValue(Value value)Returns a previously created MemValue that is equal to the supplied value, or null if the supplied value is a new value or is equal to null.MemBNodegetOrCreateMemBNode(BNode bnode)SeegetOrCreateMemValue(Value)for description.MemLiteralgetOrCreateMemLiteral(Literal literal)SeegetOrCreateMemValue(Value)for description.MemResourcegetOrCreateMemResource(Resource resource)SeegetOrCreateMemValue(Value)for description.MemIRIgetOrCreateMemURI(IRI uri)SeegetOrCreateMemValue(Value)for description.MemValuegetOrCreateMemValue(Value value)Gets or creates a MemValue for the supplied Value.-
Methods inherited from class org.eclipse.rdf4j.model.base.AbstractValueFactory
createBNode, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createLiteral, createStatement, createStatement, createTriple
-
-
-
-
Constructor Detail
-
MemValueFactory
public MemValueFactory()
A cache of the most common IRIs to improve lookup performance when users use our vocabularies (eg.RDF.TYPE).
-
-
Method Detail
-
clear
public void clear()
-
getMemValue
public MemValue getMemValue(Value value)
Returns a previously created MemValue that is equal to the supplied value, or null if the supplied value is a new value or is equal to null.- Parameters:
value- The MemValue equivalent of the supplied value, or null.- Returns:
- A previously created MemValue that is equal to value, or null if no such value exists or if value is equal to null.
-
getMemResource
public MemResource getMemResource(Resource resource)
See getMemValue() for description.
-
getMemLiteral
public MemLiteral getMemLiteral(Literal literal)
See getMemValue() for description.
-
getMemURIs
@Deprecated(forRemoval=true, since="4.0.0") public Set<MemIRI> getMemURIs()
Deprecated, for removal: This API element is subject to removal in a future version.Use getMemIRIsIterator() instead.Gets all URIs that are managed by this value factory.Warning: This method is not synchronized.
- Returns:
- An unmodifiable Set of MemURI objects.
-
getMemBNodes
@Deprecated(forRemoval=true, since="4.0.0") public Set<MemBNode> getMemBNodes()
Deprecated, for removal: This API element is subject to removal in a future version.Use getMemBNodesIterator() instead.Gets all bnodes that are managed by this value factory.Warning: This method is not synchronized.
- Returns:
- An unmodifiable Set of MemBNode objects.
-
getMemLiterals
@Deprecated(forRemoval=true, since="4.0.0") public Set<MemLiteral> getMemLiterals()
Deprecated, for removal: This API element is subject to removal in a future version.Use getMemLiteralsIterator() instead.Gets all literals that are managed by this value factory.Warning: This method is not synchronized.
- Returns:
- An unmodifiable Set of MemURI objects.
-
getMemIRIsIterator
public WeakObjectRegistry.AutoCloseableIterator<MemIRI> getMemIRIsIterator()
Gets all URIs that are managed by this value factory.- Returns:
- An autocloseable iterator.
-
getMemBNodesIterator
public WeakObjectRegistry.AutoCloseableIterator<MemBNode> getMemBNodesIterator()
Gets all bnodes that are managed by this value factory.- Returns:
- An autocloseable iterator.
-
getMemLiteralsIterator
public WeakObjectRegistry.AutoCloseableIterator<MemLiteral> getMemLiteralsIterator()
Gets all literals that are managed by this value factory.- Returns:
- An autocloseable iterator.
-
getOrCreateMemValue
public MemValue getOrCreateMemValue(Value value)
Gets or creates a MemValue for the supplied Value. If the factory already contains a MemValue object that is equivalent to the supplied value then this equivalent value will be returned. Otherwise a new MemValue will be created, stored for future calls and then returned.- Parameters:
value- A Resource or Literal.- Returns:
- The existing or created MemValue.
-
getOrCreateMemResource
public MemResource getOrCreateMemResource(Resource resource)
SeegetOrCreateMemValue(Value)for description.
-
getOrCreateMemURI
public MemIRI getOrCreateMemURI(IRI uri)
SeegetOrCreateMemValue(Value)for description.
-
getOrCreateMemBNode
public MemBNode getOrCreateMemBNode(BNode bnode)
SeegetOrCreateMemValue(Value)for description.
-
getOrCreateMemLiteral
public MemLiteral getOrCreateMemLiteral(Literal literal)
SeegetOrCreateMemValue(Value)for description.
-
createIRI
public IRI createIRI(String uri)
Description copied from interface:ValueFactoryCreates a new IRI from the supplied string-representation.- Specified by:
createIRIin interfaceValueFactory- Overrides:
createIRIin classAbstractValueFactory- Parameters:
uri- A string-representation of a IRI.- Returns:
- An object representing the IRI.
-
createIRI
public IRI createIRI(String namespace, String localName)
Description copied from interface:ValueFactoryCreates a new IRI from the supplied namespace and local name. Calling this method is funtionally equivalent to callingcreateIRI(namespace+localName), but allows the ValueFactory to reuse supplied namespace and local name strings whenever possible. Note that the values returned byIRI.getNamespace()andIRI.getLocalName()are not necessarily the same as the values that are supplied to this method.- Specified by:
createIRIin interfaceValueFactory- Overrides:
createIRIin classAbstractValueFactory- Parameters:
namespace- The IRI's namespace.localName- The IRI's local name.
-
createBNode
public BNode createBNode(String nodeID)
Description copied from interface:ValueFactoryCreates a new blank node with the given node identifier.- Specified by:
createBNodein interfaceValueFactory- Overrides:
createBNodein classAbstractValueFactory- Parameters:
nodeID- The blank node identifier.- Returns:
- An object representing the blank node.
-
createLiteral
public Literal createLiteral(String value)
Description copied from interface:ValueFactoryCreates a new literal with the supplied label. The return value ofLiteral.getDatatype()for the returned object must bexsd:string.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
value- The literal's label, must not be null.- Returns:
- A literal for the specified value.
-
createLiteral
public Literal createLiteral(String value, String language)
Description copied from interface:ValueFactoryCreates a new literal with the supplied label and language attribute. The return value ofLiteral.getDatatype()for the returned object must berdf:langString.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
value- The literal's label, must not be null.language- The literal's language attribute, must not be null.- Returns:
- A literal for the specified value and language attribute.
-
createLiteral
public Literal createLiteral(String value, IRI datatype)
Description copied from interface:ValueFactoryCreates a new literal with the supplied label and datatype.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
value- The literal's label, must not be null.datatype- The literal's datatype. If it is null, the datatypexsd:stringwill be assigned to this literal.- Returns:
- A literal for the specified value and type.
-
createLiteral
public Literal createLiteral(String value, CoreDatatype datatype)
Description copied from interface:ValueFactoryCreates a new literal with the supplied label and datatype.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
value- The literal's label, must not be null.datatype- The literal's datatype. It may not be null.
-
createLiteral
public Literal createLiteral(boolean value)
Description copied from interface:ValueFactoryCreates a new xsd:boolean-typed literal representing the specified value.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
value- The value for the literal.- Returns:
- An xsd:boolean-typed literal for the specified value.
-
createLiteral
public Literal createLiteral(XMLGregorianCalendar calendar)
Description copied from interface:ValueFactoryCreates a new literal representing the specified calendar that is typed using the appropriate XML Schema date/time datatype.- Specified by:
createLiteralin interfaceValueFactory- Overrides:
createLiteralin classAbstractValueFactory- Parameters:
calendar- The value for the literal.- Returns:
- A typed literal for the specified calendar.
-
-