× 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.



Armbruster, Tom wrote:
Thanks. I see. A global variable like system time, system date, or
some random global environment variable used by the overall application
by reference could change during the call. That makes the question more
sensible. Although memory is at a premium on some systems ...

While passing by reference will conserve memory, the time efficiency is also much better than passing by value for large parameters. To me, this is the much more important difference between passing by value and passing by reference.


... I've always
found that a constant SHOULD be a temporary variable that can not be
altered.

Short version:
If you really want to be absolutely sure that this happening, use VALUE instead of CONST. There will be an adverse effect on performance for large parameters. As Jon Paris mentioned, there is currently no way to do this in RPG when making a program call.

Long version:
Adding 'CONST' to a prototype is really just a convenience to those who might call your program/procedure. You're saying 'you can pass me pointers into your programs memory, and I promise I won't mess with your memory'. The idea being that the calling program can take advantage of the efficiencies gained by passing by reference without being concerned about what might happen to the variable in question. Having the compiler stop you from messing with the CONST parameter is just a convenience to help you not to accidentally break the promise. As usual, if you do something really wacky like directly using a global variable in a subprocedure, you can trick the compiler enough that it can't help you anymore.

There is also a handy extra benefit promising the caller that you won't change a parameter passed by reference. It allows the compiler to do some fancy tricks to make things more convenient for the calling programmer, like converting your 3,0 packed to a 5,2 zoned before making the call so that the programmer doesn't have to worry about it. The only reason the compiler can do this is because it knows that the calling program isn't expecting to receive a result from the called procedure in that variable.

Hope this helps,
Adam

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

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.