栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java三种多线程实现睡眠排序

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java三种多线程实现睡眠排序

原文链接:https://5hx.ink/?p=168

1、继承Thread类,重写run( )方法

2、实现Runnable接口,重写run( )方法

3、实现Callable接口,重写call( )方法并使用FutureTask获取call( )方法的返回结果

①继承Thread类,实现睡眠排序

class SleepSort extends Thread {
    private int num;
    public SleepSort(int num) {
        this.num = num;
    }
    public void run(){
        try{
            sleep(num*10);
        }catch (Exception e){
            e.printStackTrace();
        }
        System.out.print(num+" ");
    }
    public static void main(String[] args) {
        int nums[]={56,41,75,84,91,14,7,64,32};
        for (int num : nums) {
            SleepSort thread = new SleepSort(num);
            thread.start();
        }
    }
}

②实现Runnable接口,实现睡眠排序

public class SleepSort implements Runnable {
    private int num;
    public SleepSort(int num) {
        this.num = num;
    }
    public void run() {
        try{
            Thread.currentThread().sleep(num*10);
        }catch (Exception e){
            e.printStackTrace();
        }
        System.out.print(num+" ");
    }
    public static void main(String[] args) {
        int nums[]={56,41,75,84,91,14,7,64,32};
        for (int num : nums) {
            SleepSort mr = new SleepSort(num);
            Thread t1 = new Thread(mr);
            t1.start();
        }
 
    }
}

③实现Callable接口,实现睡眠排序

import java.util.concurrent.Callable;
import java.util.concurrent.FutureTask;
 
public class SleepSort implements Callable {
    private int num;
    public SleepSort(int num) {
        this.num = num;
    }
    public Object call() throws Exception {
        try {
            Thread.sleep(num*10);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.print(num+" ");
        return "";
    }
 
    public static void main(String[] args) {
        int nums[]={56,41,75,84,91,14,7,64,32};
        for (int num : nums) {
            SleepSort myThreadCall = new SleepSort(num);
            FutureTask integerFutureTask = new FutureTask<>(myThreadCall);
            new Thread(integerFutureTask).start();
        }
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/865560.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号