今天逛博客,发现原来单例的实现用枚举类型是最提倡的。赶紧记录到我的java学习笔记中。_代码很简洁:
/**
* 这是就是我们要的Single
*/
public enum Single {
instanse;
int i;
public void someMethod(){
System.out.println("someMethod");
}
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
}
/**
* 这是调用示例
*/
public class Demo {
public static void main(String[] args){
Single s = Single.instanse;
s.setI(100);
System.out.println(s.getI());
s.someMethod();
}
}
此外下面是之前写的代码:
public class Single1 {
static UploadTaskQueue queue = null;
public static UploadTaskQueue getUploadTaskQueue() {
if(queue == null) {
queue = new UploadTaskQueue();
}
return queue;
}
}
最近才发现上面的代码属于线程不安全的。比如在queue还未被实例化之前同一时刻有两个线程都执行到if(queue == null),那么这两个线程都会去执行queue = new UploadTaskQueue()。最后的结果是两个线程得到的queue不是同一个。毕竟我这菜鸟写的代码没有经过太多的推敲O(∩_∩)O~。解决方案可以看下这篇文章:
抛砖引玉
网友评论