|
the classic example is C++...
the problem with this approach is what do you do if the driver CL modulenever ends? It's function is to process requests from a data queue. By never
On Mon, Jun 23, 2008 at 9:10 AM, Aaron Bartell <aaronbartell@xxxxxxxxx>
wrote:
thatThe difference is the RPG has to handle the reference counting and objectcleanup ( dealloc once the object is no longer referenced. )
By that statement do you mean the RPG programmer has to keep track of
or the RPG runtime?
the classic example is C++ where the programmer has a ton of
facilities in the form of constructors, destructors, assignment
operator overloading, ... with which to manage memory allocations.
The programmer has to do the work of writing the code that keeps track
of the allocated memory. In that setting, the runtime cant manage the
memory your program allocates.
I guess the way I look at it is a piece of memory inexpired
both languages would be put up for re-allocation once the scope had
(i.e. local variables within a sub procedure, setting on *INLR, ending an
activation group). How are they different other than OS/400 has had this
"reclaiming of resources) for probably much longer than Java/C#? (which I
would also translate into it most likely being much more robust and
efficient)
I agree. Reclaiming the activation group can/does function like a GC.
You could use SQL CLI to write an RPG module that called an sql
procedure and converted the result set returned by that procedure into
a memory resident collection of tables. Then return that allocated
mass of data to a CL module caller in the same activation group. The
CL module then calls another RPG module in the same AG, passing
different data collections with SQL like instructions to join, select
and order them. The called RPG module executes the SQL like
instructions by reading the meta data in the collections which
describe the data ( table names, column names, column data types ).
That module returns a resulting collection which has been allocated in
the AG. etc, etc. When the CL driver module ends, the AG is
destroyed, and all the memory is reclaimed.
the problem with this approach is what do you do if the driver CL
module never ends? It's function is to process requests from a data
queue. By never returning, the AG would not be reclaimed, and the job
would eventually have gigabytes of memory allocated.
-Steve
--
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.