|
Barbara, That is going to get tricky when you embed Java in a subprocedure. The code I am working with is supposed to hide these types of problems. I also can't guarantee what will be called when and certainly don't know when something is no longer needed. Does the JVM end on an error? In a similar situation (fortunately all RPGIV) I registered a cleanup routine. If the object wasn't registered you could not use the procedures in this case that required the help of a cleanup. In this case the Cleanup object might contain a vector so I would wrap newString('blablabla') with something like regClean(newString('blablalba')) with regClean taking an object and putting that reference in some sort of collection. A registered exit would perform the cleanup by calling another method in Cleanup. David Morris >>> bmorris@ca.ibm.com 02/08/02 03:23PM >>> >Date: Fri, 08 Feb 2002 15:03:49 -0700 >From: "David Morris" <David.Morris@plumcreek.com> > >Thanks for the tip. You are right that it not intuitive to have to >clean up a reference to a String. I changed that code from >something that looked like the following because nested >calls were getting hard to follow. > > invElement = newElement(newString('invoice')); > >In this case I am guessing that it holds the reference from >the invElement and will allow garbage collect for the string >when the element is released. If this is the case I will try to >use this notation. Sorry David, that's even worse. That way, you don't even have a chance to get the reference to free it later. RPG doesn't do any garbage collection at all (except for objects it implicitly creates, like Java arrays for array parameters). Java can't, because it doesn't know the difference between the 2-statement version and the nested version. From its point of view there are just 2 calls. Barbara Morris
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.