[問題] function如何回傳陣列(矩陣)

作者: bmw530li ( )   2012-06-01 00:14:48
想使用function回傳一整個陣列而不是一個數值,不知到與法該怎麼用
program main
real*8, allocatable :: a(:,:),a1(:,:))
integer*4 :: b=3
allocate (a(b,b),a1(b,b))
!allocate (a1(b,b))
allocate (a2(b,b))
a=0.d0; a1=0.d0;
a1(1,1:3)=1.5d0;
a(2,1:3)=2d0*a1(1,1:3)+5d0
write(*,*) a;
write(*,*) a1;
print * , '\'
write(*,*) add(b,a,a1)
pause
stop
end program main
function add(b,a,a1)
integer*4 :: b
real*8,allocatable :: a(:,:),a1(:,:)
allocate( a(b,b),a1(b,b) )
real*8, dimension(b,b) :: add
add=a+a1
return
end function add
跑出兩個錯誤訊息,不知道與法該怎麼用QQ
Error: A specification statement cannot appear in the executable section.
real*8, dimension(b,b) :: add
作者: biggun (大槍)   2012-06-01 11:03:00
第一個錯誤 請把宣告放在 allocate 前面第二個錯誤 屬於基本問題 請看有關陣列運算的章節
作者: terryys (terry)   2012-06-01 11:20:00
第二個錯誤其實就是第一個引起的,解決第一個就可以了但是副程式要用allocatable的話要加interface,或者把它用contains包在主程式內對了,你這個程式裡還有另外的錯誤,但都容易解決
作者: bmw530li ( )   2012-06-01 15:10:00
所以要用到interface就是了?我再看看,感謝
作者: kermomo (小柯)   2012-06-12 03:52:00
我的經驗是把這種函數寫在MODULE再USE該MODULE就行了

Links booklink

Contact Us: admin [ a t ] ucptt.com