1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
|
program subroutines_03
implicit none
integer :: i, j, k, l
i = 1
j = 1
k = 1
l = 1
call f(i, j, k, l)
print *, j
if (j /= 4) error stop
call f(i, j, d=l, c=k)
print *, j
if (j /= 4) error stop
call f(a=i, b=j, d=l, c=k)
print *, j
if (j /= 4) error stop
call f(b=j, a=i, c=k, d=l)
print *, j
if (j /= 4) error stop
contains
subroutine f(a, b, c, d)
integer, intent(in) :: a, c, d
integer, intent(out) :: b
b = a + 1 + c + d
end subroutine
end program
|