• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

GO语言(七)多核并行化的问题

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
 1 package main
 2 
 3 import "fmt"
 4 
 5 type Vector []float64
 6 
 7 func (v Vector) DoSome(i,n int, u Vector, c chan float64) {
 8   var sum float64
 9   for ; i<n; i++ {
10     sum += u[i]
11   }
12   c <- sum 
13 }
14 
15 const NCPU =  2
16 
17 func (v *Vector) DoAll(u Vector) {
18   c := make(chan float64, NCPU)   //根据自己电脑的CPU产生对应个数的管道
19 
20   for i:=0; i<NCPU; i++ {
21     go v.DoSome(i*len(u)/NCPU, (i+1)*len(u)/NCPU, u, c)
22   }
23 
24   var sum float64 = 0.00
25   for i:=0; i<NCPU; i++ {
26     sum += <-c 
27   }
28   fmt.Println(sum)
29 }
30 
31 func main() {
32   var v Vector
33   u := []float64{1.00, 2.00, 3.00, 4.00, 5.00, 6.00}
34 
35   v.DoAll(u)
36 }

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
VSCode下go环境配置【终结版】发布时间:2022-07-10
下一篇:
Windows64VisualStudioCode安装go插件失败分析及解决方案发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap