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类,如果需要传参数,可以建立构造方法传参。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)