睡眠算法<个人娱乐>

  最近看到一个非常有意思的排序算法,各元素分别分配一个线程,然后按元素大小,决定线程睡眠时常

刚好最近在了解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.脑洞比较大

posted @ 2018-11-06 16:25  vike0906  阅读(461)  评论(0编辑  收藏  举报