Subprograms A subprogram allows process (as opposed to data) abstraction. Characteristics –single entry point –caller suspended until control returns from subprogram –control returns to caller when subprogram terminates only if subprogram terminates normally exceptions allow for alternate control flow Types –Functions: return a value –Procedures: do not return a value –Predicates: are provable (or not)
Parameters Formal parameters/parameters –in subprogram definition Actual parameters/arguments –in subprogram call Binding of arguments to parameters –positional (1 st is bound to 1 st, 2 nd to 2 nd, etc) –keyword (each parameter has a keyword
Keyword parameter example (defun makePoint (&key x y)...) (makePoint :x 3 :y 5) (makePoint :y 5 :x 3) This example is Lisp. Other languages that permit keyword arguments include Ada and Fortran95.
Default arguments C++, Fortran95, Ada and PHP allow default argument values void example(int x=100, int y) {...} example(30) example(100,30) example(50,30) example(50,30)
Variable-length parameter lists Some languages allow subprograms to accept a variable number of arguments. –Lisp, Scheme, C#, Java (define f (lambda (x y)...)) f takes a list of two args (define g (lambda lst...)) g takes a list of unspec len
Java varargs example void foo(int x, String... names) { System.out.println(“x is ”+x); for (String name:names) { System.out.println(name); } Vararg must be last parameter.
Parameter passing modes in –information passes in through parameter out –information passes out through parameter in-out –information passes both in and out through parameter
passing modes in-mode –pass-by-value out-mode –pass-by-result in-out mode –pass-by-value-result –pass-by-reference –(pass-by-name: textual substitution)