一,重写(Overide)和重载(Overload)

:方法的重写和重载都是多态的体现。重载是编译型多态,重写是运行时多态。

1.重写:发生在继承关系中,子类继承了父类的原有方法,但在某些情况下,子类并不想继承原有的方法,对继承的方法(方法名,参数列表,返回类型和父类一致,并且子类函数的访问修饰权限不能少于父类的,若父类修饰符是public,则子类不能用protected,若父类修饰符是private,则子类无法继承)进行方法体重写。

public class A {

    public static void main(String[] args) {
        B b=new B();
        b.test();
    }
    public void test(){
        System.out.println("A");
    }
}
class B extends A{
    @Override
    public void test(){
        System.out.println("B");
    }
}
//答案:B

2.重载:发生在本类方法中,是类中多态性的表现,要求同名方法参数列表不同(参数类型,参数个数和参数顺序),返回值类型可以相同也可以不同。无法以返回值类型作为区分重载的标准。

public class A {

    public static void main(String[] args) {
        A a=new A();
        a.test(1,2);
        a.test(1);
    }
    public void test(int i,int j){
        System.out.print("A");
    }
    public void test(int i){
        System.out.print("B");
    }
}
//答案:AB

二:封装、继承和多态

1.封装:封装的核心是私有(private)。封装一般用来封装对象的属性,很少封装方法。例如下面的类A中,将属性封装,设置get和set方法来操作私有的属性。

public class A {
    private String name;
    private int age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

2.继承:继承就是子类继承父类的方法和属性,私有的不能被继承。Java只能单继承,父类可以有多个子类,子类只能由一个父类。子类拥有父类的非private方法,同时也可以拓展自己的方法。

3.多态:1.是继承;2有方法的重写;3父类引用指向子类对象;4编译看左边,运行看右边

三、Java设计模式:

设计模式是一套经过反复使用的代码设计经验,目的是为了重用代码,让代码更容易被他人理解,保证代码可靠性。

1.总的来说,设计模式被分为三大类

创建型模式:共5种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式
结构型模式:共7种:适配器模式、装饰器模式、代理模式、桥接模式、外观模式、组合模式、享元模式
行为型模式:共11种:策略模式、模板方法模式、观察者模式、责任链模式、访问者模式、中介者模式、迭代器模式、命令模式、状态模式、备忘录模式、解释器模式

还有两类:并发型模式和线程池模式

2.设计模式的六大原则

1>开闭原则: 开闭原则指的是对扩展开放,对修改关闭。在对程序进行拓展时,不能去修改原有的代码,使用抽象类或接口。

2>依赖倒转原则:依赖倒转原则是开闭原则的基础,系统面向接口编程,依赖于抽象而不依赖于具体。

3>里氏替换原则:里氏替换原则指的是任何基类出现的地方,子类一定可以出现。里氏替换原则是对开闭原则的补充,实现开闭原则的关键是抽象化,而基类与子类的继承关系就是抽象化的具体实现,所以里氏替换原则是对实现抽象化的具体步骤的规范。

4>接口隔离原则:使用多个隔离的接口比使用单个接口好,降低接口之间的耦合度和依赖。

5>迪米特原则:最少知道原则。一个类应当尽量减少与其他实体类相互作用,使得系统功能模块相对独立,降低耦合度。

6>合成复用原则:尽量使用组合/聚合的方式,而不是继承。

3.Java设计模式:创建型:单例模式:

单例模式可以确保系统中某个类只有一个实例,该类自行实例化并向整个系统提供这个实力的公共访问点,除了该公共访问点不能通过其他途径访问该实例。

优点:1系统中只存在一个共用的实例对象,无需频繁创建和销毁对象,节约了系统资源,提高了系统性能;2可以严格控制客户何时何方法访问单例对象

特点:1单例类只能有一个实例对象 2单例类必须自己创建自己的唯一实例 3单例类必须给所有其他对象提供这一实例。

在计算机系统中,线程池,缓存,日志对象,对话框,打印机,显卡的驱动程序对象通常被设计为单例,这些应用或多或少具备资源管理器的作用。

1.懒汉式单例

public class Singleton {
    private Singleton(){}
    private static Singleton singleton=null;
    //静态工厂方法
    public static  Singleton getInstance(){
        if(singleton==null){
           singleton=new Singleton();
        }
        return singleton;
    }

}

以上懒汉式单例模式线程不安全,为确保线程安全,提供以下三种方法,都是对getInstance进行改造

1.1.加synchronized同步机制(缺点:每次都需要同步,影响性能)

public class Singleton {
    private Singleton(){}
    private static Singleton singleton=null;
    //静态工厂方法
    public static synchronized Singleton getInstance(){
        if(singleton==null){
           singleton=new Singleton();
        }
        return singleton;
    }

}

1.2双重检查锁定:使用两个if做判断,确保了只有第一次调用单例的时候才会做同步,避免了资源的浪费;volatile关键字的作用是禁止指定重排序

public class Singleton {
    private Singleton(){}
    private volatile static  Singleton singleton=null;
    public static  Singleton getInstance(){
        if(singleton==null){
            synchronized(Singleton.class){
                if(singleton==null){
                    singleton=new Singleton();
                }
            }

        }
        return singleton;
    }
}

1.3静态内部类(利用类加载机制保证初始化instance时只有一个线程,同时保证线程安全)

public class Singleton {
    private static class LazyHolder{
        private static final Singleton INSTANCE=new Singleton();
    }
    public Singleton(){}
    public static final Singleton getInstance(){
        return LazyHolder.INSTANCE;
    }
}

2.饿汉式单例(在类初始化时,已经自行实例化,线程安全)

public class Singleton {
    private Singleton(){}
    private static final Singleton singleton=new Singleton();
    public static Singleton getInstance(){
        return singleton;
    }
}