睡眠算法<个人娱乐>

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

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

转载于:https://www.cnblogs.com/vike0906/p/9916041.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值