JAVA 多线程实际运用(Callable,Runnable)

JAVA 多线程实际运用(Callable,Runnable),第1张

JAVA 多线程实际运用(Callable,Runnable)

Runnable 无返回值

Callable 有返回值

先看 Runnable 

这里我直接新建的main方法来演示

public static void main(String[] args) {
        ExecutorService executorService = Executors.newFixedThreadPool(50);
        MyRunnable myRunnable = new MyRunnable();
        System.out.println(new Date());
        for (int i = 0; i < 50; i++) {
            executorService.execute(myRunnable);
        }
        System.out.println(new Date());
    }

ExecutorService 是线程的service对象,Executors.newFixedThreadPool(50);表示这个线程池中最多可以同时运行50个线程,这里可以根据实际业务情况做出调整;

同时我们要新建MyRunnable类,这里面写的是我们需要多线程去运行的代码

public class MyRunnable implements Runnable {

    @Override
    public void run() {
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        System.out.println("执行线程了");
    }

}
 

这里我们实现的是Runnable类,执行效果如下

可以看到控制台上先打印了两个时间,而后执行了多线程的方法打印的内容才显示出来,但其实代码运行的顺序是不变的,多线程的代码块其实在第二个print之前就运行了,但我们实际上在多线程的方法体内加入了Thread.sleep(500),所以这里多线程的方法执行时main方法的代码就已经运行到了下一步,而我们这50条线程执行的内容几乎是同一时间打印出来的,也可以证明程序是在同时运行这50个线程的。

再来看Callable

同样是使用 ExecutorService ,但这一次用的是submit方法提交线程,这个方法会返回Future对象,这个对象就是线程的返回值

同样,使用Callable也需要建立一个类,这次要实现的是Callable类,如果需要传参数,可以建立构造方法传参。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zaji/5708141.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存