Subjects
Home
VOTE Move XML Commons to Xerces
Commented: (XERCESJ 589) Bug with pattern restriction on long strings
: Xerces J 2 8 1 Release on Wednesday, September 13th
: Xerces J 2 9 0 Release on Wednesday, November 22nd
Commented: (XERCESJ 1066) Restriction+choice+substitutionGroup error
Commented: (XERCESJ 1178) Error getting prefix for an attribute with no n
Updated: (XERCESJ 1244) XMLSchemaValidator does not contribute element 's
Some consideration about the xerces DOM implementation
Updated: (XERCESJ 1066) Restriction+choice+substitutionGroup error
Commented: (XERCESJ 1227) Poor performance / OutOfMemoryError for sequenc
retain exception stack traces
Updated: (XERCESJ 1193) NPE or hang when parsing using the "continue afte
Future of NekoHTML
Commented: (XERCESJ 1203) NPE in XMLDTDProcessor
DOM Level 3 APIs for Xalan J and a new Xalan release (2 7 1)
: xml commons external 1 3 04 Release on Wednesday, November 22nd
Commented: (XERCESJ 1247) Incorrect location information on SAX when usin
XInclude exceptions how to mirror Xerces J functionality into Xerces C++?
First proposal on SoC project "Add support for the StAX (JSR 173) cursor API
: xml commons resolver 1 2 Release on Wednesday, November 22nd
Typo in RangeToken java Please check
Validator features
java lang ClassCastException when adopting Node
using the org apache xerces impl xs identity package
Updated: (XERCESJ 1257) buffer overflow in UTF8Reader for characters out
Problem with ref attributes and schema validation
Updated: (XERCESJ 122) XMLSchemaValidator does not contribute element 's d
Performance problem under load Xerces with Weblogic 9 x
remove ignored memory allocation
Commented: (XERCESJ 1177) SAXXMLStreamReader doesn 't always report namesp
Commented: (XERCESJ 977) Null pointer exception during DOM parsing
Commented: (XERCESJ 1197) Code cleanup for org apache xml serialize
Commented: (XERCESJ 1201) Initial contribution for StAX Event API
Updated: (XERCESJ 1061) Regex "$ " and "^ " characters treated as special c
Commented: (XERCESJ 1199) SAXXMLStreamReader should attempt to register a
Commented: (XERCESJ 1061) Regex "$ " and "^ " characters treated as special
Updated: (XERCESJ 589) Bug with pattern restriction on long strings
StackOverflow
xerces Range unnecessarily not garbage collectable if not detached
Updated: (XERCESJ 1178) Error getting prefix for an attribute with no nam
Bug in xs:redefine
Commented: (XERCESJ 1204) Can not set XMLEntityResolver for LSParser
Updated: (XERCESJ 1253) Prototype for SoC2007 project "Add support for th
Updated: (XERCESJ 1259) Add SteamFilter Function to SoC2007 project "Add
Assigned: (XERCESJ 444) SAXException thrown by EntityResolver is reported
Google Summer of Code 2007
Xerces J and XInclude relative path issue
Assigned: (XERCESJ 206) Stack overflow when using a schema validation
Commented: (XERCESJ 1215) Restrictions involving two levels of substituti
Closed: (XERCESJ 1203) NPE in XMLDTDProcessor
non overriding equals methoda
Resolved: (XERCESJ 1079) invalid value returned for TOTALDIGITS facet in
Xerces AS3 port
Updated: (XERCESJ 325) Regular Expression; Pattern "| " clause order de
Updated: (XERCESJ 1196) Javadoc generation fails on Java SE 5 0
Closed: (XERCESJ 1202) DTD validation on XIncluded documents when the sch
Created: (XERCESJ 1124) Nonspecific schema error message
a bug in xerces
Updated: (XERCESJ 1201) Initial contribution for StAX Event API
Closed: (XERCESJ 1254) Empty uris in targetNamespace attribute not report
Links
Home
Oracle database error code
 
Search:  
Power your search with and, or, +, -, or "some phrase" operators.
xerces Range unnecessarily not garbage-collectable if not detached...

xerces Range unnecessarily not garbage-collectable if not detached...

2007-03-11       - By Michael Glavassevich
Reply:     1     2     3  

Hi Ludger,

"Ludger Buenger" <ludger.buenger@(protected)> wrote on 03/08/2007
05:47:34 AM:

> Hi Michael, thanks for your quick answer.
>
> Ok, Here I send a first proposal for changes as a patch regarding
> Ranges and weak references.
> It should not be difficult to apply similar changes to NodeIterators.

Thanks for the contribution. Could you please create a new JIRA issue [1]
and attach your patch to it?

I also need to ask you to fax an Individual Contributor License Agreement
(CLA) [2] to Apache since I couldn't find one on file [3] for you.
According to the Xerces project charter [4] in order to accept new
features and other enhancements into the project the developer
contributing the code must have a CLA on file with Apache. Signing a CLA
will cover your improvements for Ranges as well as future contributions to
Xerces (and other Apache projects).

> A more optimized implementation would likely make use of reference
> queues removing the need to actively check the weak reference's
> content upon each range update by DocumentImpl.
>
> Since I am not proficient regarding java.io.Serialization at all
> someone more competent in this matter has to check whether something
> like this would break serializability.

I can take care of that. I suspect the ranges field should be made
transient. Not sure why it wasn't declared transient in the first place.

> Internally we were also thinking about EventListeners to use
> WeakReferences however I think that references to objects provided
> by an external application should not be weak (which I think applies
> to EventListener and user data).
>
> However classes xerces provides to the application where xerces
> stores an reference in order to be able to update it's content can
> be weak and thus garbage collectable (which I think applies to
> Ranges and NodeIterators).
>
>
> The following is a use case where a weak reference to an
> EventListener could cause undesired behaviour.
>
> Imagine an EventListener implementation that solely logs all events
> to System.out or a file:
>
> node.addEventListener(MutationEventImpl.DOM_SUBTREE_MODIFIED,
>             new EventListener() {
>                 public void handleEvent( Event evt ) {
>                     System.out.println( "Subtree Modification Event
> occured" );
>                 }
>             }, true );
>
>
> The only reference to this EventListener resides inside the DOM
> implementation.
> If I am not mistaken usage of WeakReferences inside the DOM
> implementation here would result in the logging EventListener
> eventually being garbage-collected and thus cease event logging, right?

Yes, but that's not what I was thinking of. It's not the EventListener or
the user data which needs the WeakReference. It's the node that they're
associated with that needs it.

In order to save memory per node instance we decided to store
EventListeners and user data on the Document node in Hashtables. When you
register an EventListener or set user data it's inserted into one of these
Hashtables along with the associated node (which is the key). If you later
remove the node from its parent in the DOM and drop all your references to
it, it and the EventListener/user data can't be garbage collected because
the Document still has references to them. To get the node to be GC'd you
would also have to remove the EventListener or user data from the node.
Certainly less intuitive than Range.detach() and only necessary because of
an implementation decision we made. Applications shouldn't be expected to
do that.

> Same applies to user data: It might happen, that an application
> provides user data and relies upon the node implementation to hold
> on to it until the application retrieves the user data from the node
again.
>
>
> Thanks,
>
> Ludger B�nger
> --
> Dipl.Inf. Ludger B�nger
> RealObjects GmbH

[1] http://issues.apache.org/jira/browse/XERCESJ
[2] http://www.apache.org/licenses/icla.txt
[3] http://people.apache.org/~jim/committers.html
[4] http://xml.apache.org/xerces2-j/charter.html

Michael Glavassevich
XML Parser Development
IBM Toronto Lab
E-mail: mrglavas@(protected)
E-mail: mrglavas@(protected)

---------------------------------------------------------------------
To unsubscribe, e-mail: j-dev-unsubscribe@(protected)
For additional commands, e-mail: j-dev-help@(protected)