形状引継ぎ配列
主プログラムで宣言した配列の大きさを、副プログラム側に引き継ぐ。
副プログラム側では、配列の大きさを宣言する必要がなくなる。
ただし、主プログラム側で、interface文を使う必要がある。
プログラム例
主プログラム:test_cal_sum.f90
- test_cal_sum.f90 1KB ダウンロード
program test_cal_sum
! Description:
!
! Author: am
!
! Host: aofd30
! Directory: /work2/am/teaching/21.Fortran/01.interface
!
! Revision history:
! 2011-05-09 08:42
! Initial Version
! use
! implicit none
interface
subroutine cal_sum(a, s)
real,intent(in) :: a(:)
real,intent(out) :: s
end subroutine cal_sum
end interface
integer,parameter :: n=10
real a(n)
write(*,'(a)')'Program test_cal_sum starts.'
! write(*,*)''
do i=1,n
a(i)=float(i)
enddo !i
call cal_sum(a,s)
print *,'i, a(i)'
do i=1,n
print *,i,a(i)
enddo !i
print *
print *,'sum= ',s
print *
write(*,'(a)')'Done program test_cal_sum.'
write(*,*)
end program test_cal_sum
副プログラム:cal_sum.f90
- cal_sum.f90 1KB ダウンロード
subroutine cal_sum(a,s)
! Description:
!
! Author: am
!
! Host: aofd30
! Directory: /work2/am/teaching/21.Fortran/01.interface
!
! Revision history:
! 2011-05-09 08:42
! Initial Version
real,intent(in) :: a(:)
real,intent(out) :: s
write(*,'(a)')'Subroutine: cal_sum'
write(*,*)''
n=size(a,1)
print *,'n= ',n
do i=1,n
s=s+a(i)
enddo !i
write(*,'(a)')'Done subroutine cal_sum.'
write(*,*)
end subroutine cal_sum
使用例
コンパイル
makefile:
- makefile 3KB ダウンロード
$ make
make: Warning: File `makefile' has modification time 4.3e+02 s in the future
if [ ! -d ../obj ]; then \
mkdir -p ../obj ; \
fi
ifort -c -module ../obj -c -o ../obj/cal_sum.o cal_sum.f90
ifort -c -module ../obj -c -o ../obj/test_cal_sum.o test_cal_sum.f90
ifort -o test_cal_sum ../obj/cal_sum.o ../obj/test_cal_sum.o -module ../obj
make: warning: Clock skew detected. Your build may be incomplete.
real 0m0.097s
user 0m0.054s
sys 0m0.041s
実行例
$ ./test_cal_sum
Program test_cal_sum starts.
Subroutine: cal_sum
n= 10
Done subroutine cal_sum.
i, a(i)
1 1.000000
2 2.000000
3 3.000000
4 4.000000
5 5.000000
6 6.000000
7 7.000000
8 8.000000
9 9.000000
10 10.00000
sum= 55.00000
Done program test_cal_sum.