场景
有人问到,静态工具类的方法会有多线程问题么。 这是个好问题,值得探讨。
分析解答
这个要区分下,静态方法是为了解决什么问题呢。 是普通的工具方法,例如日期转换等。还是用来处理共享值的静态方法。
普通静态方法
例如,日期转换,编码解码等。这种最简单,不需要考虑共享变量。
静态方法多线程下会异步执行。
处理共享值的静态方法
例如:抢票等。 这种稍复杂。 因为要保证共享值的正确操作,所以需要加锁。
静态方法加了synchronized,之后会等待。 而且所有加了synchronized的statis方法都会等待锁。
代码
ThreadDemo代码:
public class ThreadDemo implements Runnable{
public void run(){
Utils.m();
Utils.m1();
Utils.m2();
}
public static void main(String[] args) {
for (int i=0;i<3;i++){
new Thread(new ThreadDemo()).start();
}
System.out.println(1);
}
}
Utils代码(utils是静态工具类):
public class Utils {
public static void m(){
try {
Thread.sleep(3000);
System.out.println("m: "+new Random().doubles());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public synchronized static void m1(){
try {
Thread.sleep(3000);
System.out.println("m1: "+new Random().doubles());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public synchronized static void m2(){
try {
Thread.sleep(3000);
System.out.println("m2: "+new Random().doubles());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
输出结果如下:
1
m: java.util.stream.DoublePipeline$Head@5169ce60
m: java.util.stream.DoublePipeline$Head@655a2155
m: java.util.stream.DoublePipeline$Head@30b1d31
m1: java.util.stream.DoublePipeline$Head@5fae2a3d
m1: java.util.stream.DoublePipeline$Head@46098334
m2: java.util.stream.DoublePipeline$Head@54daa4ca
m1: java.util.stream.DoublePipeline$Head@6b9dc38e
m2: java.util.stream.DoublePipeline$Head@6fa24a25
m2: java.util.stream.DoublePipeline$Head@5b91a510