单例模式:

 1 public  class Person{
 2 public static Person per//定义一个静态变量,用来储存当前类的对象
 3 private Person()//构造方法私有化
 4 {
 5 }
 6 public static Person getInstance()//定义一个静态方法,用来获取当前类的实例
 7 {
 8 if(per==null 9 {
10 per=this11 }
12 return this13 }
14 
15 }
16 public class Student{
17 
18 Person per=Person.getInstance();//调用静态方法
19 } 

思考:如何实现多线程下的单例模式呢?
首先我们要知道单例分为两种模式:

懒汉模式和恶汉模式。

懒汉模式:在类加载的时候不创建实例,运行调用的时候创建类。优点:加载速度快!缺点:在运行的时候获取对象慢!

以上的代码就是懒汉式,符合多线程下的单例模式,但是多线程下一般不使用!

饿汉模式:在类加载时,就完成初始化,所以类加载慢。但是在运行时获取对象的速度快!

 

 1 class Person
 2 {
 3  private Person person=null;
 4  private Person () {}
 5  public Person getInstance()
 6  {
 7  if(person==null)
 8 {
 9  person =new Person();
10  }
11  return person;
12  }
13 
14 }*/
15 class Person
16 {
17  private Person person=null;
18 private Person () {}
19 public Person getInstance()
20  {
21  if(person==null)
22 {
23  synchronized(this)
24 {
25  if(person==null)
26  person =new Person();
27 
28  }
29  }
30 51return person ;
31 }
32 }
33 /*
34  *
35  * 这样在synchronized 线程控制块里面进行多线程的控制,就不会再出现多个线程访问时出现多个对象的情况了.
36  * 还有一点就是外面的person ==null 判断是用来提高效率的,不然第一次都要对锁进行判断,消耗浓资源
37  * 这样可以有次的提高效率
38  * */
39 public class Single {
40  public static void main(String args[])
41  {
42  System.out.println("this is java");
43  }
44 }

在创建实例的方法中有两部判断,一步锁。如果代码进入到了第一步判断直接进入判断,多线程谁先进谁就能先得到对象。如果该线程对象为空,将当前类的对象交给它,继续等待下一个进程的进入。由于使用synchronized锁定,无法同时进入多个线程(排队的形式!)