24小时热门版块排行榜    

查看: 3248  |  回复: 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的回帖

鸿影惊天下

金虫 (小有名气)

引用回帖:
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的回帖
查看全部 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的回帖

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的回帖

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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 275求调剂 +4 太阳花天天开心 2026-03-16 4/200 2026-03-17 10:53 by 功夫疯狂
[考研] 268求调剂 +6 一定有学上- 2026-03-14 7/350 2026-03-17 10:14 by Sammy2
[论文投稿] 有没有大佬发小论文能带我个二作 +3 增锐漏人 2026-03-17 4/200 2026-03-17 09:26 by xs74101122
[考研] 一志愿,福州大学材料专硕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 热情沙漠
[考研] 东南大学364求调剂 +5 JasonYuiui 2026-03-15 5/250 2026-03-16 21:28 by 木瓜膏
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[考研] 311求调剂 +5 26研0 2026-03-15 5/250 2026-03-16 16:21 by a不易
[考研] 085600调剂 +5 漾漾123sun 2026-03-12 6/300 2026-03-16 15:58 by 漾漾123sun
[考研] 085600材料与化工 求调剂 +13 enenenhui 2026-03-13 14/700 2026-03-16 15:19 by 了了了了。。
[考研] 312求调剂 +3 陌宸希 2026-03-16 4/200 2026-03-16 15:06 by peike
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
[考研] 070305求调剂 +3 mlpqaz03 2026-03-14 4/200 2026-03-15 11:04 by peike
[考研] 复试调剂 +4 z1z2z3879 2026-03-14 5/250 2026-03-14 16:30 by JourneyLucky
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 332求调剂 +3 zjy101327 2026-03-11 6/300 2026-03-13 22:48 by JourneyLucky
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] [0860]321分求调剂,ab区皆可 +4 宝贵热 2026-03-13 4/200 2026-03-13 22:01 by 星空星月
[考研] 材料工程调剂 +4 咪咪空空 2026-03-11 4/200 2026-03-13 19:57 by JourneyLucky
[考研] 274求调剂0856材料化工 +12 z2839474511 2026-03-11 13/650 2026-03-13 10:39 by peike
信息提示
请填处理意见