睡眠算法<个人娱乐>
最近看到一个非常有意思的排序算法,各元素分别分配一个线程,然后按元素大小,决定线程睡眠时常
刚好最近在了解Go语言,便用java和go分别实现了该算法,感觉挺有意思的,在此分享一下
java:
int [] item = {3,2,5,1,8,4,6,9,7,0}; for(int i : item){ new Thread(()->{ try { Thread.sleep(1000*i); System.out.printf("%d ",i); } catch (InterruptedException e) { e.printStackTrace(); } }).start(); }
go:
item := [] int {3,2,5,1,8,4,6,9,7,0}
var bc = make(chan int, len(item)) for i := range item{ go func (index int){ time.Sleep(time.Duration(index)*time.Second) bc <- index }(i) } for range item { fmt.Printf("%d, ",<-bc) }
PS.脑洞比较大