• 7天学完Java基础之5/7


    接口

    接口就是一种公共的规范标准 是一种引用数据类型

    定义格式

    public interface 接口名称{}

    java7 中接口可以包含常量,抽象方法;Java8 还可以额外包含默认方法,静态方法;Java 9 还可以额外包含私有方法

    public interface MyInterfaceAbstract{
        //这是一个抽象方法
        public abstract void methodAbs();
        //接口中的抽象方法,修饰符必须是两个固定的关键字:public abstract
        //这两个关键字可以选择性的省略
        abstract void methodAbs2();
        public void methodAbs3();
        void methodAbs4();
        
    }
    

    接口的抽象方法使用

    接口使用步骤:

    1. 接口不能够直接使用,必须有一个“实现类”来实现该接口

      格式:

      public class 实现类名称 implements 接口名称{}

    2. 接口的实现类必须覆盖重写接口中所有的抽象方法

    3. 创建实现类对象(new),进行使用

    //按照定义格式定义一个接口
    //public interface 接口名称{}
    public interface InterfaceDemo {
        //接口里面可以有抽象方法,普通方法
        //定义一个抽象方法
        public abstract void methodAbs1();
        //默认方法
        public abstract void methodAbs2();
    
    }
    
    public class InterfaceDemoImpl implements InterfaceDemo{
        //回顾一些重写的概念
        //方法名和形参列表一样
        //权限修饰符必须大于或者等于父类的权限修饰符
        //子类的返回值类型必须小于或者等于父类的返回值类型
        @Override
        public void methodAbs1() {
            System.out.println("天下武功,唯快不破");
        }
    
        @Override
    
        public void methodAbs2() {
            System.out.println("认真的人,自带光芒");
        }
    
    }
    
    public class newInterfaceDemo {
        public static void main(String[] args){
            InterfaceDemoImpl inter = new InterfaceDemoImpl();
            inter.methodAbs1();
            inter.methodAbs2();
        }
    }
    
    注意事项

    如果实现类并没有覆盖重写接口中的所有的抽象方法,那么这个实现类就必须是抽象类

    接口的默认方法定义
    public interface InterfaceDemo {
        /*
        java 8开始,接口允许定义默认方法
        格式:
        public default 返回值类型 方法名称(参数列表){
        方法体
        }
        备注:接口当中的默认方法,可以解决接口升级的问题
        默认方法可以有方法体
         */
        public abstract void methodAbs1();
    
        public default void methodAbs2(){
            System.out.println("我是默认方法,可以解决升级问题");
        }
    
    public class InterfaceDemoImpl implements InterfaceDemo{
        @Override
        public void methodAbs1() {
            System.out.println("天下武功,唯快不破");
        }
        //我在这里并没有重写public default void methodAbs2()
        //实现接口自动继承方法
    }
    
    
    public class newInterfaceDemo {
        public static void main(String[] args){
            InterfaceDemoImpl inter = new InterfaceDemoImpl();
            //接口的默认方法也是可以覆盖重写的
            //这里就不写了
            inter.methodAbs1();
            inter.methodAbs2();
        }
    }
    
    接口的静态方法的定义
    /*
    格式
    public static 返回值类型 方法名称(参数列表){}
    
     */
    public interface InterfaceStatic {
        public static void method1(int a,int b){
            System.out.println("今天要敲"+a*b+"行代码");
        }
    }
    
    public class InterfaceStaticImpl {
        //接口中的静态方法的使用
        public static void main(String[] args) {
            //直接通过接口名称.静态方法的名称调用即可
            InterfaceStatic.method1(15,67);
        }
    }
    
    接口的私有方法定义
    /*
    问题描述:
    我们需要抽取一个共有方法,用来解决两个默认方法之间重复代码的问题
    但是这个共有方法,不应该被是实现类使用,应该私有化的
    
    解决方案
    从Java 9 开始,接口当中允许定义私有方法
    1.普通私有方法,解决多个默认方法之间重复代码问题
    格式
    private 返回值类型 方法名称(参数列表){}
    2.静态私有方法,解决多个静态方法之间重复代码问题
        格式:
        private static 返回值类型 方法名称(参数列表){}
     */
        public interface InterfaceStatic {
            public default void method1(){
                System.out.println("认真的人,自带光芒");
                method3();
            }
            public default void method2(){
                System.out.println("作日的最佳表现,是今日的最低要求");
                method3();
            }
            private void method3(){
                System.out.println("乘风破浪会有时,直挂云帆济沧海");
            }
    }
    
    public class InterfaceStaticImpl implements InterfaceStatic{
        public static void main(String[] args) {
            InterfaceStaticImpl inter = new InterfaceStaticImpl();
            inter.method1();
            inter.method2();
            //接口中的静态方法的使用
            //想要使用接口的方法,必须要实现接口
            //实现完接口后,需要new对象使用
        }
    
    }
    
    接口的常量定义和使用

    1.接口当中的常量,可以省略public static final ,注意,不写也照样是这样

    1. 接口当中的常量,必须进行复制,不赋值不能使用

    2. 接口当中的常量名称,使用完全大写的字母,用下划线进行分割

    使用格式

    接口名称.常量名称

    多态

    多态的前提:extends继承或者Implements实现,

    一个对象拥有多种形态,这就是:对象的多态性

    代码当中体现多态性:父类引用指向子类对象

    多态格式

    父类名称 对象名 = new 子类名称();

    或者

    接口名称 对象名= new 实现类名称();

    多态中成员变量的使用特点

    //访问成员变量的两种方式
    //1.直接通过对象名称访问成员变量:看等号左边是谁,优先用谁,没有向上找
    //2.间接通过成员方法访问
    public class Fu {
        //子类也有相同的成员变量num
        int num = 10;
    
        public void shownum(){
            System.out.println(num);
        }
    }
    
    public class Zi extends Fu{
        //与父类相同的成员变量num
        int num = 20;
        //子类特有的成员变量
        int num1 =30;
        //重写方法
        @Override
        //重写了父类的方法,
        public void shownum(){
            System.out.println(num);
        }
    }
    
    
    public class Demo01MultiField {
        public static void main(String[] args) {
            //使用多态的写法,父类引用指向子类对象
            Fu obj  = new Zi();
            //等号左边是Fu,优先使用左边的的成员变量,没有则向上找
            System.out.println(obj.num);//10
            //不可能向下找
            //System.out.println(obj.num1);编译报错
    
            //shownum属于Fu,则使用Fu的成员变量//10
            //当子类覆盖重写父类,就属于Zi类//20
            obj.shownum();
        }
    }
    

    多态中成员方法的使用特点

    public class Fu {
        //成员方法的访问规则
        //看new的是谁,就优先用谁,没有则向上找
        public void method(){
            System.out.println("我是父类");
        }
        public void methodFu(){
            System.out.println("我是父类特有方法");
        }
    }
    
    public class Zi extends Fu{
        public void method(){
            System.out.println("我是子类");
        }
        public void methodZi(){
            System.out.println("我是子类特有方法");
        }
    }
    

    java

    public class Demo01MultiField {
        public static void main(String[] args) {
           Fu obj  = new Zi();//多态
           obj.method();// 父子都有,new的是zi,优先用zi  //输出结果我是子类
           obj.methodFu();//子类没有,向上找,           //输出结果我是父类特有方法
        }
    }
    

    多态中成员变量访问规则和成员方法访问规则总结

    成员变量:看左边,左边是哪一个类就优先使用哪一个类。没有像上找

    成员方法:看右边,new的是哪一个对象就优先使用哪一个对象的方法。没有向上找

    对象的向上转型

    1. 对象的向上转型,其实就是多态的写法

      格式 父类名称 对象名 = new 子类名称();

      含义:右侧创建一个子类对象,把他当作父类来看待使用

      Animal animal = new Cat();创建了一只猫,当作动物看待

    注意事项:向上转型一定是安全的从小范围(猫)转成大范围(动物)

    对象的向下转型

    对象的向下转型,其实是一个还原的动作

    格式:子类名称 对象名 = (子类名称)父类对象;

    含义,将父类对象,还原成本来的子类对象

    Animal animal = new Cat();//本来是猫,向上转型成为动物
    Cat cat = (cat) animal;//本来是猫,已经被当成动物了,还原回来成为本来的猫向下转型;
    
    

    instanceof关键字进行类型判断

    格式:

    对象 instanceof类名称

    这将会得到一个Boolean值结果,也就是判断前面的对象能不能当作后面类型的实例

    笔记本USB接口案例

    //先确定一下笔记本电脑有什么功能
    //关机,开机,可以使用各种USB设备
    //功能确定好之后写方法
    public class Computer {
        public void powerOn() {
            System.out.println("笔记本电脑开机了");
        }
    
        public void powerOff() {
            System.out.println("笔记本电脑关机了");
        }
    
        public void usbDevice(USB usb) {
            usb.open();
            if (usb instanceof Mouse) {
                Mouse mouse = (Mouse) usb;
                mouse.click();
            } else if (usb instanceof KeyBoard) {
                KeyBoard keyboard = (KeyBoard) usb;
                keyboard.type();
            }
            //usb.close();
        }
    }
    
    
    //usb设备需要设置成接口,并且有抽象方法,
    //因为usb设备都有着共性的方法,和非共性的方法,我们需要把共性的方法给抽取出来
    //usb设备都有开关的功能
    public interface USB {
        //打开设备的功能
        public abstract void open();
        //关闭设备的功能
    
        public abstract void close();
    
    }
    
    //现在设置一个usb设备
    //去实现USB接口
    //实现了这个USB接口才可以在Computer类中传递进去,有了USB设备,鼠标才是一个完整的电脑
    //现在就去实现这个接口吧
    public class Mouse implements USB {
        //必须重写抽象方法
        @Override
        public void open() {
            System.out.println("鼠标插入");
        }
        @Override
        public void close() {
            System.out.println("鼠标拔出");
        }
        //鼠标特有的方法
        public void click() {
            System.out.println("鼠标点击");
        }
    }
    
    //也是一个USB设备
    public class KeyBoard implements USB {
        //重写方法
        @Override
        public void open() {
            System.out.println("键盘插入。。。");
        }
        @Override
        public void close() {
            System.out.println("键盘拔出");
        }
        //键盘特有方法
        public void type() {
            System.out.println("键盘打字");
        }
    }
    
    //现在可以创建一个计算机了
    public class ComputerImple {
        public static void main(String[] args) {
            //创建一个笔记本对象
            Computer computer = new Computer();
            //启动笔记本
            computer.powerOn();
            //创建USB接口
            USB usb = new Mouse();
            //传递接口
            computer.usbDevice(usb);
            USB usb1 = new KeyBoard();
            computer.usbDevice(usb1);
            //关闭笔记本
            computer.powerOff();
    
        }
    }
    
  • 相关阅读:
    LSTM模型与前向反向传播算法
    循环神经网络(RNN)模型与前向反向传播算法
    卷积神经网络(CNN)反向传播算法
    卷积神经网络(CNN)前向传播算法
    卷积神经网络(CNN)模型结构
    深度神经网络(DNN)的正则化
    深度神经网络(DNN)损失函数和激活函数的选择
    ubuntu下如何编译openthread?
    linux下如何删除空行?
    vi下什么快捷键可以完成大小写转换?
  • 原文地址:https://www.cnblogs.com/train99999/p/10887926.html
Copyright © 2020-2023  润新知