|
fkany=xyKOxUUvAoHhjpcFh+TbANBPR1lH4CV8@public.gmane.org wrote:
Hi everyone, I've been trying to figure out the difference between an RPG subprocedure and an RPG program. So far, I don't see much of a difference on how they take in data, process the data and send it back. Lets say I have a subprocedure that converts an incoming date format to another date format. Someone could also write a small program that does the same thing. Why would a programmer choose writing a subprocedure over writing a program? I hope I'm not asking too silly of a question. Thanks for all your help.
Everyone has been offering some good answers already, but I'll just add my own two cents worth: At a high level of abstraction, yes, they are quite the same. They are both means of splitting an application into more meaningful chunks of code. In OPM, applications are split up into programs. In ILE (like practically all other OS environments), applications can be split up into programs and service programs, which themselves can be split up into modules consisting of procedures. Designing how you split up the responibilities into these various pieces can be one of the trickiest aspects of software development. At a lower level, there are some functional differences between programs and procedures. Both accept parameters by address (by CONST or by reference). But procedures also accept parameters passed by VALUE, and can return values. Also, as others have pointed out, there are performance differences between calling programs and procedures. Generally, since the address of a procedure is known at bind time, procedure calls are much faster. As a rough rule of thumb, use procedures as your primary mechanism for decomposing your application. Use programs for separate tasks, and use service programs for procedures commonly used by a number of programs. Cheers! Hans
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.