24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 2024  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 332求调剂 +17 小小孟... 2026-04-05 18/900 2026-04-06 09:51 by 蓝云思雨
[考研] 一志愿 江南大学 085602 化工专硕 338分求调剂 +15 路痴小琪 2026-04-05 15/750 2026-04-06 09:27 by cql1109
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +13 努力奋斗112 2026-04-04 13/650 2026-04-06 07:13 by jj987
[考研] 复试调剂 +8 春日来信- 2026-04-03 8/400 2026-04-05 18:58 by 蓝云思雨
[考博] 申博 +7 IQwQl 2026-04-04 7/350 2026-04-04 23:32 by mumin1990
[考研] 344材料与化工调剂 +9 调剂上岸玘 2026-04-03 9/450 2026-04-04 23:10 by happyddm
[考研] 0854求调剂 +4 assdll 2026-04-03 4/200 2026-04-04 22:17 by hemengdong
[考研] 环境285分,过六级,求调剂 +10 xhr12 2026-04-02 10/500 2026-04-04 21:53 by bn53987
[考研] 一志愿南昌大学324求调剂 +9 hanamiko 2026-03-30 9/450 2026-04-04 11:04 by 猪会飞
[考研] 282求调剂 +20 ycy1201 2026-04-01 22/1100 2026-04-04 00:42 by userper
[考研] 本科985,专业0812分336求调剂 +4 莫莫很行 2026-04-03 4/200 2026-04-03 21:31 by zhq0425
[考研] 求调剂 +8 akdhjs 2026-04-03 8/400 2026-04-03 18:17 by 戴维ING
[考研] 工科341分调剂 +3 洛多罗 2026-04-03 3/150 2026-04-03 14:20 by 1753564080
[考研] 一志愿北京交通大学材料工程总分358 +4 cs0106 2026-04-03 4/200 2026-04-03 13:41 by 百灵童888
[考研] 081200-11408-276学硕求调剂 +3 崔wj 2026-04-02 3/150 2026-04-02 15:06 by cal0306
[考研] 07生物学求调剂 一志愿同济大学359分 +3 LAMC. 2026-03-30 3/150 2026-04-02 10:26 by 18828373951
[考研] 286求调剂 +5 Sa67890. 2026-04-01 7/350 2026-04-01 19:50 by 6781022
[考研] 350求调剂 +7 阿佳~ 2026-03-31 7/350 2026-04-01 16:12 by yanflower7133
[考研] 求0861交通运输专硕or材料专硕调剂 +4 勒布朗@ 2026-03-31 4/200 2026-04-01 09:54 by 一只好果子?
[考研] 考研材料工程351分调剂 +5 整个好的 2026-03-31 5/250 2026-04-01 09:36 by topgun2009
信息提示
请填处理意见