最简单的单线程变多线程的例子
背景
不知道你项目里有么有这样一个函数,这个函数里调用了大概十几来个函数,这十几个函数依次的从头写到位,而且这几个函数都是相对独立的,谁先执行谁后执行都互不影响。
最简单的优化
最简单的优化,原本这几个操作是单线顺序执行的,只要把互相独立的操作变成多线程的就可以了
下面是一个最直接的例子:
public class SingleThread {
@Test
public void single() {
long time1 = System.currentTimeMillis();
fun1();
fun2();
long time2 = System.currentTimeMillis();
System.out.println(time2 - time1);
}
@Test
public void multiple() throws Exception {
ExecutorService executor = Executors.newFixedThreadPool(2);
long time1 = System.currentTimeMillis();
Future future1 = executor.submit(this::fun1);
Future future2 = executor.submit(this::fun2);
future1.get();
future2.get();
long time2 = System.currentTimeMillis();
System.out.println(time2 - time1);
}
public Object fun1() {
try {
Thread.sleep(1000L);
} catch (Exception ignore) {
}
return "1";
}
public Object fun2() {
try {
Thread.sleep(2000L);
} catch (Exception ignore) {
}
return "2";
}
}
从上面的例子可以看出, single()
方法是单线程的,而 multiple()
方法是多线程的,效率提高的不是一星半点。
Original: https://www.cnblogs.com/eaglelihh/p/15487228.html
Author: eaglelihh
Title: 最简单的单线程变多线程的例子
原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/587205/
转载文章受原作者版权保护。转载请注明原作者出处!