| 本文实例讲述了go语言睡眠排序算法。分享给大家供大家参考。具体分析如下: 睡眠排序算法是一个天才程序员发明的,想法很简单,就是针对数组里的不同的数开多个线程,每个线程根据数的大小睡眠,自然睡的时间越长的,数越大,哈哈,搞笑吧,这种算法看起来很荒唐,但实际上很天才,它可以充分利用多核cpu进行计算。 复制代码 代码如下:package mainimport (
 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语言程序设计有所帮助。 (编辑:源码网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |