加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.0577zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

go语言睡眠排序算法实例分析

发布时间:2016-12-04 12:04:35 所属栏目:教程 来源:站长网
导读:本文实例讲述了go语言睡眠排序算法。分享给大家供大家参考。具体分析如下: 睡眠排序算法是一个天才程序员发明的,想法很简单,就是针对数组里的不同的数开多个线程,每个线程根据数的大小睡眠,自然睡的时间越长的,数越大,哈哈,搞笑吧,这种算法看起来

本文实例讲述了go语言睡眠排序算法。分享给大家供大家参考。具体分析如下:

睡眠排序算法是一个天才程序员发明的,想法很简单,就是针对数组里的不同的数开多个线程,每个线程根据数的大小睡眠,自然睡的时间越长的,数越大,哈哈,搞笑吧,这种算法看起来很荒唐,但实际上很天才,它可以充分利用多核cpu进行计算。

复制代码 代码如下:package main
import (
nbsp;nbsp;nbsp; "fmt"
nbsp;nbsp;nbsp; "time"
)
func main() {
nbsp;nbsp;nbsp; tab := []int{1, 3, 0, 5}
nbsp;
nbsp;nbsp;nbsp; ch := make(chan int)
nbsp;nbsp;nbsp; for _, value := range tab {
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; go func(val int){
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; time.Sleep( int64(val)*10000000 )
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; fmt.Println(val)
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; ch lt;-val
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; }(value)
nbsp;nbsp;nbsp; }
nbsp;nbsp;nbsp; for _ = range tab {
nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp;nbsp; lt;-ch
nbsp;nbsp;nbsp; }
}

希望本文所述对大家的Go语言程序设计有所帮助。

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读