24小时热门版块排行榜    

查看: 3252  |  回复: 9
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

鸿影惊天下

金虫 (小有名气)

[求助] 主程序中未分配的可变数组,如何在子程序中调用?

请前辈们帮忙,自己编的一段程序:
Program test_main
    implicit none
    integer NP,ele_n,NE,NNE,npt,num
    integer,pointer :: ele_concentrate( : ),ele_c( : )
    double precision,pointer::vcl( : , : )                           
   
    interface
    subroutine new_node(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
    implicit none
    integer NP,ele_n,NE,NNE,npt,num
    integer,allocatable :: ele_concentrate(NE),ele_c(NNE)
    double precision,allocatable :: vcl(2,npt)
    end subroutine new_node

    subroutine zhaobian_gj01(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
    implicit none
    integer NP,ele_n,NE,NNE,npt,num
    integer :: ele_concentrate(NE),ele_c(NNE)
    double precision ::vcl(2,npt)
    end subroutine zhaobian_gj01
    end interface   

call zhaobian_gj01(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)   
call new_node(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
end

后面的zhaobian_gj01, new_node是子程序经调试没有错误,但是主程序在调试过程中总报错。
一个错误是可变数组ele_concentrate,ele_c,vcl:ALLOCATABLE or POINTER attribute dictates a deferred-shape-array  
另外一个错误是An allocatable dummy argument may only be argument associated with an allocatable actual argument.   同样也是可变数组出错。
两个错误都出在interface块。



求有经验的前辈帮忙指点一二!谢谢

[ Last edited by 鸿影惊天下 on 2014-3-4 at 15:06 ]
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

你所能经历的最大冒险,就是过你梦想的生活
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

btx97

金虫 (小有名气)

引用回帖:
3楼: Originally posted by 鸿影惊天下 at 2014-03-04 10:02:28
对不起我不是很明白,你的意思是vcl这个数组定义成(2,: )是已经给定了大小吗?我把interface块改成这样:
interface
    subroutine new_node(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
    imp ...

double precision,allocatable :: vcl(:,就行了,确定大小用allocate(vcl(2,npt))
4楼2014-03-04 18:03:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 10 个回答

btx97

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
鸿影惊天下: 金币+10, ★★★很有帮助, 谢谢! 2014-03-05 14:25:43
double precision,allocatable :: vcl(2,npt)

这里不用allocatable,因为你后面已经给定数组大小了,不需要申请可变数组了。
2楼2014-03-04 16:07:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

鸿影惊天下

金虫 (小有名气)

引用回帖:
2楼: Originally posted by btx97 at 2014-03-04 16:07:33
double precision,allocatable :: vcl(2,npt)

这里不用allocatable,因为你后面已经给定数组大小了,不需要申请可变数组了。

对不起我不是很明白,你的意思是vcl这个数组定义成(2,: )是已经给定了大小吗?我把interface块改成这样:
interface
    subroutine new_node(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
    implicit none
    integer NP,ele_n,NE,NNE,npt,num
    integer,allocatable :: ele_concentrate(NE),ele_c(NNE)
    double precision :: vcl(2,npt)
    end subroutine new_node
    end interface
   
    interface
    subroutine zhaobian_gj01(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)
    implicit none
    integer NP,ele_n,NE,NNE,npt,num
    integer,allocatable :: ele_concentrate(NE),ele_c(NNE)
    double precision ::vcl(2,npt)
    end subroutine zhaobian_gj01
    end interface

之后,vcl数组不再提示错误,但是其他两个数组还是会报原来的错误。但是如果把interface里申请可变数组的allocatable都去掉,错误提示就会变成:error #8000:  There is a conflict between local interface block and external interface block.   [ELE_CONCENTRATE]        位置是在interface里zhaobian_gj01(NP,ele_n,NE,NNE,ele_concentrate,ele_c,vcl,npt,num)这一句。

这是为什么呢?
你所能经历的最大冒险,就是过你梦想的生活
3楼2014-03-04 17:02:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

btx97

金虫 (小有名气)

引用回帖:
4楼: Originally posted by btx97 at 2014-03-04 11:03:06
double precision,allocatable :: vcl(:,就行了,确定大小用allocate(vcl(2,npt))...

double precision,allocatable :: vcl( :,: )动态数组申请的时候只需要给出rank,就是是几维的就行了
5楼2014-03-04 18:04:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 070300化学319求调剂 +3 锦鲤0909 2026-03-17 3/150 2026-03-17 15:01 by 我的船我的海
[考研] 268求调剂 +6 好运连绵不绝 2026-03-12 7/350 2026-03-17 14:56 by 呦呦忧郁
[考研] 工科材料085601 279求调剂 +3 困于星晨 2026-03-17 3/150 2026-03-17 14:08 by ms629
[考研] 一志愿,福州大学材料专硕339分求调剂 +3 木子momo青争 2026-03-15 3/150 2026-03-17 07:52 by laoshidan
[考研] 274求调剂 +5 时间点 2026-03-13 5/250 2026-03-17 07:34 by 热情沙漠
[考研] [导师推荐]西南科技大学国防/材料导师推荐 +3 尖角小荷 2026-03-16 6/300 2026-03-16 23:21 by 尖角小荷
[基金申请] 国自科面上基金字体 +6 iwuli 2026-03-12 7/350 2026-03-16 21:18 by sculhf
[考研] 0854控制工程 359求调剂 可跨专业 +3 626776879 2026-03-14 9/450 2026-03-16 17:42 by 626776879
[基金申请] 今年的国基金是打分制吗? 50+3 zhanghaozhu 2026-03-14 3/150 2026-03-16 17:07 by 北京莱茵润色
[考研] 070300化学学硕求调剂 +6 太想进步了0608 2026-03-16 6/300 2026-03-16 16:13 by kykm678
[考研] 283求调剂 +10 小楼。 2026-03-12 14/700 2026-03-16 16:08 by 13811244083
[考研] 0703化学调剂,求各位老师收留 +8 秋有木北 2026-03-14 8/400 2026-03-16 15:21 by 哦哦123
[考研] 277材料科学与工程080500求调剂 +3 自由煎饼果子 2026-03-16 3/150 2026-03-16 14:10 by 运气yunqi
[基金申请] NSFC申报书里申请人简历中代表性论著还需要在申报书最后的附件里面再上传一遍吗 20+5 NSFC2026我来了 2026-03-10 14/700 2026-03-15 23:53 by 不负韶华的虎
[考研] 331求调剂(0703有机化学 +5 ZY-05 2026-03-13 6/300 2026-03-14 10:51 by Jy?
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +6 步川酷紫123 2026-03-13 6/300 2026-03-13 21:59 by 星空星月
[考研] 290求调剂 +7 ADT 2026-03-12 7/350 2026-03-13 15:17 by JourneyLucky
[考研] 工科调剂 +4 Jiang191123! 2026-03-11 4/200 2026-03-13 15:15 by Miko19
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 333求调剂 +3 152697 2026-03-12 4/200 2026-03-13 07:08 by Iveryant
信息提示
请填处理意见