参考:https://blog.csdn.net/wangqyoho/article/details/77584832
当前对象不愿意干的,没法干的东西委托给别的对象来做
静态代理和动态代理 (静态代理事先知道要代理的是什么,而动态代理不知道要代理什么东西,只有在运行时才知道)
静态代理:扩展原功能,不侵入原代码,但是有很多方法的话,一一实现就会比较麻烦
动态代理:动态地在内存中构建代理对象,会默认实现接口的全部方法。
区别:
参考:https://segmentfault.com/a/1190000014771830
实现对象增强有三种方式:继承,包装模式,代理模式
一个接口类,一个实现接口的抽象装饰类,一个继承装饰类的实体类
优点:
缺点:
一个类中能创建一个实例,所以称之为单例。
编写单例模式的代码分了三步:
共有五种方式如下:
(1)饿汉式
// 1.将构造函数私有化,不可以通过new的方式来创建对象
private Java3y(){}
// 2.在类的内部创建自行实例
private static Java3y java3y = new Java3y();
// 3.提供获取唯一实例的方法
public static Student getJava3y() {
return java3y;
}
(2)简单懒汉式
// 1.将构造函数私有化,不可以通过new的方式来创建对象
private Java3y(){}
// 2.1先不创建对象,等用到的时候再创建
private static Java3y java3y = null;
// 2.1调用到这个方法了,证明是要被用到的了
public static Java3y getJava3y() {
// 3. 如果这个对象引用为null,我们就创建并返回出去
if (java3y == null) {
java3y = new Java3y();
}
return java3y;
}
(3)DCL懒汉式(双重安全的懒汉式)
例:
private Java3y() {}
private static volatile Java3y java3y = null;
public static Java3y getJava3y() {
if (java3y == null) {
// 将锁的范围缩小,提高性能
synchronized (Java3y.class) {
// 再判断一次是否为null
if (java3y == null) {
java3y = new Java3y();
}
}
}
return java3y;
}
(4)静态内部类懒汉式
原理: 当任何一个线程第一次调用getInstance()
时,都会使SingletonHolder被加载和被初始化,此时静态初始化器将执行Singleton的初始化操作。(被调用时才进行初始化!)
初始化静态数据时,Java提供了的线程安全性保证。(所以不需要任何的同步)
private Java3y() {
}
// 使用内部类的方式来实现懒加载
private static class LazyHolder {
// 创建单例对象
private static final Java3y INSTANCE = new Java3y();
}
// 获取对象
public static final Java3y getInstance() {
return LazyHolder.INSTANCE;
}
(5)枚举方式实现
例如:结果为 1、2、2 (只初始化了一次该对象)
public enum model {
Instance;
private model(){
System.out.println("1");
}
public void pr(){
System.out.println("2");
}
public static void main(String[] args) {
model m=model.Instance;
model m1=model.Instance;
m.pr();
m1.pr();
}
}
原文:https://www.cnblogs.com/StingLon/p/10432571.html