初识单例模式(java学习笔记)

这周的java实验就是单例模式,java老师培养我们学习英文的好方法啊。直接给我们的是一段英文的实验要求,先要我们翻译过来,才能明白具体的实验要求。

Brain Barbell

 

Earlier in this chapter, we saw that a private constructor means that the class can’t be instantiated from code running outside the class. In other words, only code from within the class can make a new instance of a class with a private constructor. (There’s a kind of chicken-and-egg problem here. ) 

What if you want to write a class in such a way that only ONE instance of it can be created, and anyone who wants to use an instance of the class will always use that one, single instance?

 

首先将以上英文翻译成中文,然后根据以上描述编写程序。


其实上面英文大体意思就是要我们实现一下单例模式。

java中单例模式是一种常见的设计模式,单例模式分三种:懒汉式单例、饿汉式单例、登记式单例三种。
单例模式有一以下特点:
1、单例类只能有一个实例。
2、单例类必须自己创建自己的唯一实例。
3、单例类必须给所有其他对象提供这一实例。
单例模式确保某个类只有一个实例,而且自行实例化并向整个系统提供这个实例。

java是一门真正面对对象的语言,java有很多种的设计模式,这里只是一个小小的开始吧。

懒汉式单例:在类初始化时,已经自行实例化

package com.whj.design;
public class Singleton {
	private Singleton(){}//私有的默认构造方法
   private static final Singleton single=new Singleton();//这里先前这个final忘记加了,然后还使用了set
   public static Singleton getSingle() {  //方法,但是后来加上final的时候,set方法就报错了。这个地方有点
	  return single;                 //没完全搞懂
}
}

package com.whj.design;
public class Test {
	public static void main(String[] args) {
      Singleton.getSingle();
      System.out.println(Singleton.getSingle());
	}

}

单例模式只能有一个实例,在test类的时候就直接调用这个实例,要实现这样的调用的话就要在前面加上static。

懒汉式单例类.在第一次调用的时候实例化

package com.whj.design;

public class Singleton2 {
private Singleton2(){}
private static Singleton2 single=null;//这里就没有final
public synchronized static Singleton2 getInstance() {//静态工厂方法,这个地方synchronized以前没有接触过,有点不明白
if (single == null) { 
single = new Singleton2();
} 
return single;
}
public static void setSingle(Singleton2 single) {
	Singleton2.single = single;
}

}
   
package com.whj.design;

public class Test2 {

	public static void main(String[] args) {
	  Singleton2.getInstance();
	  Singleton2.setSingle(null);
      System.out.println(Singleton2.getInstance());
      System.out.println(Singleton2.getSingle());
	}

}

synchronized在方法声明时使用,放在范围操作符(public等)之后,返回类型声明(void等)之前.这时,线程获得的是成员锁,即一次只能有一个线程进入该方法,其他线程要想在此时调用该方法,只能排队等候,当前线程(就是在synchronized方法内部的线程)执行完该方法后,别的线程才能进入.(参考了别人的解释)
登记式单例还没有接触,看到了在补充。

感觉设计模式还是有点抽象,还是要自己慢慢领悟啊,任重而道远啊!!!


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值