[ 
https://issues.apache.org/jira/browse/XMLBEANS-283?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13267909#comment-13267909
 ] 

Ben Foster commented on XMLBEANS-283:
-------------------------------------

I am also seeing this memory leak from code that is using v2.5.  Is there any 
update on this or even acknowledgment from the team?
                
> Creating new cursors for the same XmlObj and selecting paths leads to memory 
> leak
> ---------------------------------------------------------------------------------
>
>                 Key: XMLBEANS-283
>                 URL: https://issues.apache.org/jira/browse/XMLBEANS-283
>             Project: XMLBeans
>          Issue Type: Bug
>          Components: Cursor
>    Affects Versions: Version 2.2
>         Environment: Java 1.4.2_10, Windows XP
>            Reporter: Tero Vuorela
>            Priority: Minor
>
> I have a reference to XmlObject that I like to keep while my application is 
> running. During run new cursor for the XmlObject is created many times and  
> selectPath(..) is called for the cursor. I call dispose() when I'm finished 
> with the cursor. However using a profiler I can see that Cursor object are 
> not garbage collected. If XmlObject would be unreferenced then all cursors 
> would be garbage collected.
> Here is an example code:
> public class XmlBeansTest
> {
>     public static void main( String[] args )
>         throws Exception
>     {
>         XmlObject xmlObj = XmlObject.Factory.parse( "<test>foobar</test>" );
>         while ( true )
>         {
>              // if xmlObj would be created here then there wouldn't any leak
>              //XmlObject xmlObj = XmlObject.Factory.parse( 
> "<test>foobar</test>" );
>             
>              XmlCursor cursor = xmlObj.newCursor();
>              cursor.selectPath( "*" );
>              // in this example case we don't do anything for selected 
> elements
>              cursor.dispose();
>         }
>     }
> }
> Above code results to increasing amount of Cursor objects.  If xmlObj is 
> created inside loop there would be any problem.
> Checking the code it seems that ChangeListener structure is Cursor and Locale 
> classes keep references alive. The problem occurs if selectPath() is called 
> because _selectPath calls Locale.registerForChange(..) that builds up 
> ChangeListener "linked list".
> I wonder if it could be possible to clear _nextChangeListener when calling 
> dispose() or some other way to tear down ChangeListener structure. I'm not 
> familiar with XmlBeans code so I don't know what could be side effects of 
> that change.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@xmlbeans.apache.org
For additional commands, e-mail: dev-h...@xmlbeans.apache.org

Reply via email to