Fortran Coder

查看: 12482|回复: 8
打印 上一主题 下一主题

[并行] 为什么多线程并行速度会比单线程慢很多?

[复制链接]

1968

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1376 元
贡献
583 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

楼主
发表于 2017-7-28 19:04:14 | 显示全部楼层

回帖奖励 +10

我的理解:
1. 并行结构最好不要包含输入输出语句,因为它们并不具有可并行性能。
2. CPU_TIME在并行结构中会重复计算,并不是真实的物理挂钟时间。你占用4个线程,每个·1秒,则cpu_time就是4秒,即使真实物理时间只过了1秒。
所以,如下是一个更好的测试程序。
[Fortran] 纯文本查看 复制代码
program main
implicit none
  include 'omp_lib.h' 
  integer i
  integer,parameter :: s=3200000
  integer :: t1 , t2
  real :: epf , nobs
  open(1,file='./epf.dat')
  call system_clock(t1)
  call omp_set_num_threads(4)
  !$OMP PARALLEL DO PRIVATE(epf,nobs)
  do i=1,s
    epf=2.0*i
    nobs=epf**2
  end do
  !$OMP END PARALLEL DO
  call system_clock(t2)
  write(*,*) t2-t1
end



您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-6-10 00:41

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表