详解Java利用ExecutorService实现同步执行大量线程
程序员文章站
2024-03-31 18:15:52
自从java1.5以后,官网就推出了executor这样一个类,这个类,可以维护我们的大量线程在操作临界资源时的稳定性。
先上一段代码吧:
testrunnable.j...
自从java1.5以后,官网就推出了executor这样一个类,这个类,可以维护我们的大量线程在操作临界资源时的稳定性。
先上一段代码吧:
testrunnable.java
public class testrunnable implements runnable { private string name; public testrunnable(string name) { this.name = name; } @override public void run() { while (true) { if (main.surplus < 0) return; main.surplus--; system.out.println(name + " " + main.surplus); } } }
main入口
public static void main(string[] args) { testrunnable runnable = new testrunnable("runnable1"); testrunnable runnable2 = new testrunnable("runnable2"); thread t1 = new thread(runnable); thread t2 = new thread(runnable2); t1.start(); t2.start(); }
这样,我们就看到了,数据肯定是乱了的,当然这个时候我们可以加上一个synchronized的关键字,但是这样也会出现点小问题的
下面我打算采用一种java内置的线程管理的机制,来解决这个问题,解决这个问题的思路大概就是,我们维护了一个线程池,当有请求操作的时候统统进入线程池,并且我们只开了一个线程,可以让请求顺序执行,顺序调用临界资源,就很安全了。
import java.util.concurrent.callable; import java.util.concurrent.executionexception; import java.util.concurrent.executorservice; import java.util.concurrent.executors; import java.util.concurrent.future; public class main { public static int surplus = 10; private executorservice executor = executors.newsinglethreadexecutor(); void addtask(runnable runnable) { executor.execute(runnable); } <v> v addtask(callable<v> callable) { future<v> submit = executor.submit(callable); try { return submit.get(); } catch (interruptedexception e) { system.out.println("interruptedexception" + e.tostring()); } catch (executionexception e) { system.out.println("executionexception" + e.tostring()); } return null; } public void testaddtask(string name) { addtask(new runnable() { @override public void run() { for (int i = 0; i < 3; i++) { if (main.surplus <= 0) return; main.surplus--; system.out.println(name + " " + main.surplus); } } }); } public void testaddtask2(string name) { int count = addtask(new callable<integer>() { @override public integer call() throws exception { for (int i = 0; i < 3; i++) { if (main.surplus <= 0) return 0; main.surplus--; system.out.println(name + " " + main.surplus); } return main.surplus; } }); } public void close() { executor.shutdown(); } public static void main(string[] args) { main main = new main(); main.testaddtask("task1"); main.testaddtask2("task2"); main.testaddtask("task3"); main.testaddtask2("task4"); main.close(); } }
在这里,我们定义了两种方法,分别是addtask,具有泛型的addtask,这两种方法实现原理都是一样的,其中一个是有回调的,一个是没有回调的,就看项目需求了吧。
然后分别调用这两个方法咯,就可以看到结果是非常有序,且不会混乱的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
详解Java利用ExecutorService实现同步执行大量线程
-
详解Java利用ExecutorService实现同步执行大量线程
-
Java利用happen-before规则如何实现共享变量的同步操作详解
-
Java利用happen-before规则如何实现共享变量的同步操作详解
-
Java实现线程同步方法及原理详解
-
Java 详解循环屏障CyclicBarrier如何实现多线程分段等待执行完成
-
java利用Future实现多线程执行与结果聚合实例代码
-
Java实现线程同步方法及原理详解
-
详解Java利用ExecutorService实现同步执行大量线程(图)
-
详解Java利用ExecutorService实现同步执行大量线程(图)