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 33 34 35 36 37 38 39 40 41 42 43 44 45
|
module callback_02
contains
subroutine cb(res, a, b, f)
real, intent(in) :: a, b
real :: res
interface
subroutine f(x, res)
implicit none
real, intent(in) :: x
real :: res
end subroutine
end interface
call f(a, res)
print *, res
call f(b, res)
print *, res
res = (b-a)*res
print *, res
end subroutine
real function foo(c, d, res)
real :: c, d, res
call cb(res, c, d, f)
foo = res
contains
subroutine f(x, res)
real, intent(in) :: x
real :: res
res = 2*x
end subroutine f
end function foo
end module
program main
use callback_02
real :: res = 0
res = foo(1.5, 2.0, res)
end program
|