go多线程求和

fsp357838 · 2016-05-13 09:00:50 · 3093 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2016-05-13 09:00:50 的主题,其中的信息可能已经有所发展或是发生改变。

以下是利用协程计算1到100亿之间的所有数的和 package main

import ( "fmt" "time" "runtime" )

var c = make(chan int)

func main() { cores := runtime.NumCPU()

start := time.Now().UnixNano()
fmt.Println(cores)
runtime.GOMAXPROCS(cores)
he := 0
max, num := 10000000000, 10
for i := 0; i < num; i++ {
    go sum((max / num) * i + 1, (max / num) * (i + 1), i)
}
for i := 0; i < num; i++ {
    he = he + <-c
}
fmt.Println("he:", he)
fmt.Println("take times is : ", (time.Now().UnixNano() - start))
//    time.Sleep(1000*time.Second)

}

func sum(min, max, number int) { s := 0 // fmt.Println("min:", min, "max:", max, "|", number) for i := min; i <= max; i++ { s = s + i } // fmt.Println(s) c <- s }


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

3093 次点击  
加入收藏 微博
1 回复  |  直到 2016-07-15 01:45:48
wangxingge
wangxingge · #1 · 9年之前

atomic 库需要用

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传