24小时热门版块排行榜    

查看: 2012  |  回复: 4

wingkin

新虫 (初入文坛)

[交流] Fortran 函数中的循环无法进行 已有4人参与

最近初学fortran,遇到一个比较怪异的问题,调试了一天也没法解决,故请教大家一下。

程序已经简化,估计里面有多余的语句,不过不是重点。

程序代码如下

------------------------------------------------------------------------------------

module aa
  type coordinate
        integer :: number, x, y, z
  end type
end module

program bb
  use aa
  implicit none


  integer, parameter :: y=4
  integer, parameter :: h=11
  integer k

k=6

call sp(k,y)

if (k==1) then
write (*,*) "ok!"
end if

  
  stop
end program

subroutine sp(k,p)
implicit none


type surf
integer :: t, x, y, z
end type
integer, parameter :: v=22
integer,intent(in):: p
integer k,n
type(surf) :: s(p)
k=0

open(v, file="a.txt",status="old"
do n=1,p
   read(v,*) s(n)%t, s(n)%x, s(n)%y, s(n)%z
   if ( s(n)%t == k ) then
    k=1
   end if
end do
return
end
--------------------------------------------------------------------------------------------
其中 a.txt 数据如下
           8          79          65           0
           3          79          65           0
           4          79          65          0
           52         79          65          0
--------------------------------------------------------------------------------------------

经调试后,发现函数只循环一次便出错了。
即 读取完 s(1)%t, s(2)%x, s(3)%y, s(4)%z  后继续读取 s(2)%t 便开始出错了。

请问为什么会出现这样的问题,同样的语句放在主函数上运行没有问题,可以完整读取a. txt的数据, 结果放进函数里面就出问题了。

谢谢大家的关注和指导
回复此楼

» 猜你喜欢

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

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

夕阳西下

金虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
主程序:integer k
             k=6
子程序:type(surf) :: s(p)
                 k=0

是不是矛盾
2楼2013-05-30 08:43:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zeppe

金虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
我在gfortran (gcc4.5.3) 下测试了楼主的程序,循环没有问题,可以正常读取。
3楼2013-05-30 10:55:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lyli982

木虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
出错提示什么哪里出错了啊?从程序上,没看出问题啊。一个小问题是k那里你肯定写的不对,主程序中是6,子程序中又赋了初值0。初值肯定不是这个值。但是这个k值不会导致出错的。
4楼2013-05-31 06:01:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

学虫dj

金虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
我测试了一下楼主的程序 没有问题,楼上提到的k不会构成错误  ,只是一个判断而已,还有楼主提到的“即 读取完 s(1)%t, s(2)%x, s(3)%y, s(4)%z  后继续读取 s(2)%t 便开始出错了”,这个不应该是这么读取吧,应该是
s(1)%t, s(1)%x, s(1)%y, s(1)%z 之后是
s(2)%t, s(2)%x, s(2)%y, s(2)%z  之后是
。。。。。。。
穷则独善其事,达则兼济天下
5楼2013-06-06 16:02:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wingkin 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 考研化学学硕调剂,一志愿985 +3 张vvvv 2026-03-15 5/250 2026-03-16 20:25 by 张vvvv
[考研] 283求调剂 +10 小楼。 2026-03-12 14/700 2026-03-16 16:08 by 13811244083
[考研] 085600调剂 +5 漾漾123sun 2026-03-12 6/300 2026-03-16 15:58 by 漾漾123sun
[考研] 070303一志愿西北大学学硕310找调剂 +5 d如愿上岸 2026-03-12 8/400 2026-03-16 15:19 by peike
[考研] 309求调剂 +5 花与叶@ 2026-03-10 5/250 2026-03-16 14:13 by 哦哦123
[基金申请] NSFC申报书里申请人简历中代表性论著还需要在申报书最后的附件里面再上传一遍吗 20+5 NSFC2026我来了 2026-03-10 14/700 2026-03-15 23:53 by 不负韶华的虎
[考研] 271求调剂 +10 生如夏花… 2026-03-11 10/500 2026-03-14 00:35 by 卖报员小雨
[考研] 2026考研调剂+本科延边大学+山东大学+生物化学与分子生物学+有项目经验 +3 ccdsscjy 2026-03-10 3/150 2026-03-14 00:12 by JourneyLucky
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] 281求调剂 +9 Koxui 2026-03-12 11/550 2026-03-13 20:50 by Koxui
[考研] 332求调剂 +3 Zz版 2026-03-13 3/150 2026-03-13 20:36 by 18595523086
[考研] 工科调剂 +4 Jiang191123! 2026-03-11 4/200 2026-03-13 15:15 by Miko19
[考研] 328化工专硕求调剂 +4 。,。,。,。i 2026-03-12 4/200 2026-03-13 14:44 by JourneyLucky
[考研] 0856化工原理 +6 z2839474511 2026-03-10 6/300 2026-03-13 10:41 by houyaoxu
[考研] 材料专硕274一志愿陕西师范大学求调剂 +4 薛云鹏 2026-03-13 4/200 2026-03-13 10:40 by 学员8dgXkO
[考研] 290求调剂 +3 ADT 2026-03-13 3/150 2026-03-13 10:19 by peike
[考研] 283求调剂,材料、化工皆可 +8 苏打水7777 2026-03-11 10/500 2026-03-13 09:06 by Linda Hu
[考研] 290求调剂 +3 柯淮然 2026-03-10 8/400 2026-03-11 13:48 by 柯淮然
[考研] 0703化学调剂 +3 三dd. 2026-03-10 3/150 2026-03-10 15:45 by peike
信息提示
请填处理意见