× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Wait, I'm confused....  Why would you need to load this structure for all
users?  Each job (ie, interactive user) is seperate from each other job.
The fact that they're invoking the procedure from a common service program
has no bearing.  Each interactive session (job) initializes this array
independently, so you'd only ever need to load this for the specific
user....

Eric DeLong
Sally Beauty Company
MIS-Project Manager (BSG)
940-297-2863 or ext. 1863



-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]On Behalf Of Dan
Sent: Tuesday, January 31, 2006 1:41 PM
To: RPG programming on the AS400 / iSeries
Subject: Re: Passing a pointer-based array as a parameter


On 1/31/06, Scott Klement <rpg400-l@xxxxxxxxxxxxxxxx> wrote:
>
> > The RPG ref on an *ENTRY PARM says "Fields or data structures defined
> with
> > the keywords BASED, IMPORT, or EXPORT" are not allowed.
>
> Passing a BASED parameter wouldn't make any sense.  Parameters are passed
> by reference (i.e. by passing the pointer to that parameter).  If you
> allowed it to be BASED and defined a pointer that it was based on, then
> it'd have two different pointers that it's based on, which doesn't make
> any sense.


Yeah, pointer newbie mistake.

Instead, you need to pass the pointer (rather than the array itself) to
> the subprocedure. The subproc can then allocate memory to it.  The pointer
> does have to be passed by reference, since %ALLOC() will need to set the
> address in that pointer.


O.k., will need to get my arms around that one.  But...

I strongly recommend that you avoid the dynamic memory allocation approach
> to this if you can possibly avoid it. It's not worth it for a measley 40k
> of data.


The range of possibly 10 to 20,000 elements is real, but the structure that
I will end up using is  30 bytes in length.  Since I plan to incorporate
this into every interactive RPG program, if I accommodate  the maximum
expected 20,000 elements, that means that every interactive program will
allocate 600,000 bytes, muliplied by 50 users, and factor in the variable of
nested calls to other interactive programs.

The problem is that I can hardcode the 20000 element array, and test it with
a few people, but I won't know the impact on performance until all 50
production users have a go at it.

Would that affect your recommendation?  If it doesn't, I'd still like to
know why you advise using dynamic memory allocation.  Is it *that* messy?

Thanks,
Dan

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

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.