菩提丶尘埃 发表于 2015-12-1 13:36:56

子程序调用问题

各位大神,请见下述子程序调用问题:
PROGRAM MAIN

IMPLICIT DOUBLE PRECISION(A-Z)                                             
INTEGER::NGZ,NBGZ,DELTA,DELTB                                                                                                                     
CHARACTER(LEN=512)::JDH      
REAL(KIND=8)::NSUM
EXTERNAL::ELEM_KA                                                      

OPEN(UNIT=1,FILE='J:\123\INPUT.DAT', STATUS='OLD')                                                                                       
OPEN(UNIT=3,FILE='J:\123\OUTPUT.DAT', STATUS='UNKNOWN')

NSUM=39

DO I=1,NSUM,1                                                                                                                                                   
READ(1,*)JDH,Z1,Z2,S,IXX,MTOT,ZCOG,JXX,JYY,JZZ!//从输入数据文件INPUT.DAT中读入已知参数 JDH,Z1,Z2,S,IXX,MTOT,ZCOG,JXX,JYY,JZZ                                                                                                                                                                                                            
         PI=3.1415926                                                                                                                              
         L=ABS(Z1-Z2)                                                                                                                                                                                                                     
CALL ELEM_KA(Z1,Z2,S,IXX,MTOT,ZCOG,JXX,JYY,JZZ,M1,M2,JXM1,JYM1,JZM1,JXM2,JYM2,JZM2) !//调用子程序ELEM_KA,通过计算获得参数M1,M2,JXM1,JYM1,JZM1,JXM2,JYM2,JZM2                                                                                                            
ENDDO
END PROGRAM MAIN

SUBROUTINEELEM_KA(Z1,Z2,S,IXX,MTOT,ZCOG,JXX,JYY,JZZ,M1,M2,JXM1,JYM1,JZM1,JXM2,JYM2,JZM2)!//子程序ELEM_KA计算过程
REAL(KIND=8)::Z1,Z2,S,IXX,MTOT,ZCOG,JXX,JYY,JZZ,M1,M2,JXM1,JYM1,JZM1,JXM2,JYM2,JZM2
MELE=0                                                               
DEN=0                                                               
M2=MTOT*(ZCOG-Z1)/(Z2-Z1)                                             
M1=MTOT-M2                                                                  
JX=JXX-M1*(Z1-ZCOG)**2-M2*(Z2-ZCOG)**2                              
JY=JYY-M1*(Z1-ZCOG)**2-M2*(Z2-ZCOG)**2                                                                  
JZ=JZZ                                                                                                                                                                                 
JXM1=JX*M1/(M1+M2)                                                                                       
JYM1=JY*M1/(M1+M2)                                                                                       
JZM1=JZ*M1/(M1+M2)                                                                                             
JXM2=JX*M2/(M1+M2)                                                                                       
JYM2=JY*M2/(M1+M2)                                                                                       
JZM2=JZ*M2/(M1+M2)                                                                                       
IYY=IXX                                                                                                   
IXY=0
WRITE(3,6) JDH,S,IXX,IXY,IYY,DEN,M1,JXM1,JYM1,JZM1,M2,JXM2,JYM2,JZM2                                       
6 FORMAT(A12,13E15.4)                                                                                       
END SUBROUTINE ELEM_KA
调试出现的错误:“J:\123\TEST.F90(19): error #6784: The number of actual arguments cannot be greater than the number of dummy arguments.   ”
出现的错误翻译过来应该是“实参的数目大于了虚参的数目”
这个究竟是啥错误啊,我必须要输出这么多参数啊
求大神指教





fcode 发表于 2015-12-1 15:58:32

我分别用 ifort,gfortran,ftn95 三个编译器编译,都成功了,并未出现您描述的问题。
页: [1]
查看完整版本: 子程序调用问题