what is the difference between static call and dynamic call?
Answer Posted / ravi
Here is the difference between static and dynamic calls, it
is mentioned very clearly in IBM COBOL Manual, read it
carefully, it should clear all your doubts regarding calls
WORKING-STORAGE SECTION.
01 PGM-NAME PIC X(08).
PROCEDURE DIVISION.
BEGIN-PARA.
MOVE “SUBPROG” TO PGM-NAME.
* Dynamic call
CALL PGM-NAME USING RECORD-1. ****** Here PGM-
NAME is called as identifier*******
*Static Call
CALL “SUBPROG” USING RECORD-2. ****** Here it is
CALL literal where literal is SUBPROG*******
If you do not know the program-name to be called until run
time, use the format CALL identifier, where identifier is a
data item that will contain the name of the called program
at run time. For example, you could use CALL identifier
when the program to be called varies depending on
conditional processing in your program. CALL identifier is
always dynamic, even if you use the NODYNAM compiler option.
Making static calls
When you use the CALL literal statement in a program that
is compiled using the NODYNAM and NODLL compiler options, a
static call occurs. With these options, all calls of the
CALL literal format are handled as static calls. In the
static CALL statement, the COBOL program and all called
programs are part of the same load module.
Making dynamic calls
When you use a CALL literal statement in a program that is
compiled using the DYNAM and the NODLL compiler options, or
when you use the CALL identifier statement in a program
that is compiled using the NODLL compiler option, a dynamic
call occurs.
Making both static and dynamic calls
You can use both static and dynamic CALL statements in the
same program if you compile the program with the NODYNAM
compiler option. In this case, with the CALL literal
statement the called subprogram will be link-edited with
the main program into one load module. The CALL identifier
statement results in the dynamic invocation of a separate
load module. When a dynamic CALL statement and a static
CALL statement to the same subprogram are issued within one
program, a second copy of the subprogram is loaded into
storage. Because this arrangement does not guarantee that
the subprogram will be left in its last-used state, results
can be unpredictable.
Performance considerations of static and dynamic calls
Because a statically called program is link-edited into the
same load module as the calling program, a static call is
faster than a dynamic call. A static call is the preferred
method if your application does not require the services of
the dynamic call.
Statically called programs cannot be deleted using CANCEL,
so static calls might take more main storage. If storage is
a concern, think about using dynamic calls. Storage usage
of calls depends on whether:
The subprogram is called only a few times. Regardless of
whether it is called, a statically called program is loaded
into storage; a dynamically called program is loaded only
when it is called.
You subsequently delete the dynamically called subprogram
with a CANCEL statement.
You cannot delete a statically called program, but you can
delete a dynamically called program. Using a dynamic call
and then a CANCEL statement to delete the dynamically
called program after it is no longer needed in the
application (and not after each call to it) might require
less storage than using a static call.
| Is This Answer Correct ? | 32 Yes | 9 No |
Post New Answer View All Answers
How is the record format of an output dataset specified?
what is SOC4 error?
What methodology can be adapted to transfer data to a program that is coded using the exec statement?
can any one plzzzzzz tell the jcl code for creating ps using idcams
Explain about ISPF/TSO Commands
What is the purpose of disp parameter?
How dummy is used in jcl?
How to override a dsn that is contained in a proc called by another proc? I need to do the override in the calling jcl?
List the different jcl statements that are not permitted in the procedures?
How does the jcl specify the job to os?
What is the purpose of dd dummy statement?
What is the function of the steplib dd statement?
Name the statement which can be used to send data to another mvs jes3 node?
What do we mean by 'Virtual storage' for a dataset and for a JOBSTEP ? What is the significance of the following statement for a programmer 'Virtual storage results in program addresses being independent of the addresses that actually exist in a computer' ?
in ways data can be passed to a COBOL program from JCL?