CGB2202面向对象第8天

面向对象第八天:

潜艇游戏第一天:

  1. 设计6个类,设计World类并测试

潜艇游戏第二天:

  1. 给6个类添加构造方法,并测试

潜艇游戏第三天:

  1. 设计侦察潜艇数组、鱼雷潜艇数组、水雷潜艇数组、水雷数组、深水炸弹数组,并测试
  2. 设计SeaObject超类,设计6个类继承超类
  3. 给SeaObject设计了两个构造方法,6个类分别调用

潜艇游戏第四天:

  1. 将侦察潜艇数组、鱼雷潜艇数组、水雷潜艇数组统一组合为SeaObject数组,并测试
  2. 在6个类中重写move()移动,并测试
  3. 画窗口

潜艇游戏第五天:

  1. 给类中成员添加访问控制修饰符
  2. 创建Images图片类

潜艇游戏第六天:

  1. 设计窗口的宽和高为常量,适当地方做修改
  2. 画海洋图、画对象:
    • 想画对象需要去获取对象的图片,每个对象都能获取图片,
      意味着获取图片行为为共有行为,所以设计在SeaObject类中,
      每个对象获取图片的行为都是不一样的,所以设计为抽象方法
      ----在SeaObject中设计抽象方法getImage()获取图片
    • 在6个派生类中重写getImage()获取对象的图片
      ----重写getImage()获取图片
    • 因为只有活着的对象才需要画到窗口中,所以需要设计对象的状态,
      每个对象都有状态,意味着状态为共有属性,所以设计在SeaObject中,
      状态一般都设计为常量,同时设计state变量表示当前状态
      ----在SeaObject中设计状态常量LIVE、DEAD,state变量表示当前状态
      后期的业务中还需要判断对象的状态,每个对象都能判断状态,
      意味着判断状态的行为为共有行为,所以设计在SeaObject中,
      每个对象判断状态的行为都是一样的,所以设计为普通方法
      ----在SeaObject中设计isLive()、isDead()判断对象的状态
    • 数据都有了就可以开画了,每个对象都能画,
      意味着画对象的行为为共有的行为,所以设计在SeaObject中,
      每个对象画对象的行为都是一样的,所以设计为普通方法
      ----在SeaObject中设计paintImage()画图片---------具体怎么画,不要求掌握
    • 画对象的行为做好了,在窗口World中调用即可:
      • 准备对象
      • 重写paint()方法------调用paintImage()方法

潜艇游戏第七天:

  1. 潜艇入场:

    • 潜艇是由窗口产生的,所以在窗口World类中设计nextSubmarine()生成潜艇对象
    • 潜艇入场为定时发生的,所以在run中调用submarineEnterAction()实现潜艇入场
      在submarineEnterAction()中:
      每400毫秒,获取潜艇对象obj,submarines扩容,将obj添加到submarines最后一个元素上

      在run()中调用submarineEnterAction()之后,一定得调用repaint()方法来重画

  2. 水雷入场:-------------今天只做一部分(剩下部分周五做)

    • 水雷是由水雷潜艇发射出来的,所以在MineSubmarine中设计shootMine()生成水雷对象
    • 水雷入场为定时发生的,所以在run中调用MineEnterAction()实现水雷入场
      在MineEnterAction()中:
      每1000毫秒…--------------周五讲
  3. 海洋对象移动(不包括战舰):

    • 对象移动为所有对象共有的行为,所以在超类SeaObject中设计抽象move()来实现移动,6个派生类中重写
    • 海洋对象移动为定时发生的,所以在run中调用moveAction()实现海洋对象移动
      在moveAction()中:
      遍历所有潜艇让潜艇动,遍历所有水雷让水雷动,遍历所有深水炸弹让深水炸弹动

潜艇游戏第八天:

  1. 深水炸弹入场:

    • 深水炸弹是由战舰发射出来的,所以在Battleship中设计shootBomb()发射深水炸弹
    • 深水炸弹入场为事件触发的,所以在侦听器中重写keyReleased()按键抬起事件:
      • 判断若按键是空格键,则获取深水炸弹对象obj,bombs扩容,将obj添加到最后一个元素上
  2. 战舰移动:

    • 战舰移动为战舰的行为,所以在Battleship中设计moveLeft()左移、moveRight()右移
    • 战舰移动为事件触发的,所以在侦听器中的keyReleased()按键抬起事件中:
      • 判断若按键是左键头,则战舰左移,若按键是右键头,则战舰右移
  3. 删除越界的对象(潜艇、水雷、深水炸弹):------保证性能

    • 在SeaObject中设计isOutOfBounds()检测潜艇是否越界,
      在Bomb/Mine中重写isOutOfBounds()检测深水炸弹/水雷是否越界
    • 删除越界的对象为定时发生的,所以在run中调用outOfBoundsAction()删除越界对象
      在outOfBoundsAction()中:
      遍历所有潜艇/水雷/深水炸弹,判断若越界了:
      则将越界元素替换为最后一个元素,缩容(缩的是最后一个元素)
  4. 设计接口:

    • 设计EnemyScore得分接口,侦察潜艇与鱼雷潜艇实现得分接口
    • 设计EnemyLife得命接口,水雷潜艇实现得命接口

回顾:

  1. 成员内部类:--------------了解
    类中套类,内部类只服务于外部类,对外不可见,内部类对象通常在外部类中创建
    内部类中可以直接访问外部类的成员(包括私有的)
    ----内部类中有个隐式的引用指向了创建它的外部类对象-------外部类名.this------API时会用
  2. 匿名内部类:------------------大大简化代码
    若想创建一个类(派生类)的对象,并且对象只创建一次,建议做匿名内部类
    匿名内部类默认外面的变量是final的------------------------------API时会用
    所有类都有独立的.class

笔记:

  1. 接口:
    • 是一种引用数据类型
    • 由interface定义
    • 只能包含常量和抽象方法
    • 接口不能被实例化(new对象)
    • 接口是需要被实现/继承的,实现类/派生类:
      ----必须重写所有抽象方法
    • 一个类可以实现多个接口,用逗号分隔,若又继承又实现时,应先继承后实现
    • 接口可以继承接口
    //接口的演示
    public class InterfaceDemo {
        public static void main(String[] args) {
            //Inter5 o1 = new Inter5(); //编译错误,接口不能被实例化
            Inter5 o2 = new Doo(); //向上造型(可以造型为它所实现的接口)
            Inter4 o3 = new Doo(); //向上造型
        }
    }
    
    //演示接口继承接口
    interface Inter4{
        void show();
    }
    interface Inter5 extends Inter4{
        void test();
    }
    class Doo implements Inter5{
        public void test(){}
        public void show(){}
    }
    
    //演示接口多实现
    interface Inter2{
        void show();
    }
    interface Inter3{
        void test();
    }
    abstract class Boo{
        abstract void say();
    }
    class Coo extends Boo implements Inter2,Inter3{
        public void show(){}
        public void test(){}
        public void say(){}
    }
    
    //演示接口的实现
    interface Inter1{
        void show(); //访问权限默认是public
        void test();
    }
    class Aoo implements Inter1{
        public void show(){} //重写接口中的抽象方法,访问权限必须是public
        public void test(){}
    }
    
    //演示接口的语法
    interface Inter{
        public static final int NUM = 5; //接口中成员的访问权限只能是public的
        public abstract void show();
        int COUNT = 6; //默认public static final
        void say(); //默认public abstract
        //int number; //编译错误,常量必须声明同时初始化
        //void test(){} //编译错误,抽象方法不能有方法体
    }
    

精华笔记:

  1. 接口:
    • 是一种引用数据类型
    • 由interface定义
    • 只能包含常量和抽象方法
    • 接口不能被实例化(new对象)
    • 接口是需要被实现/继承的,实现类/派生类:
      ----必须重写所有抽象方法
    • 一个类可以实现多个接口,用逗号分隔,若又继承又实现时,应先继承后实现
    • 接口可以继承接口

补充:

  1. 越界检测图:
    CGB2202面向对象第8天_第1张图片
  2. 关系:
    • 类和类---------------------继承extends
    • 接口和接口---------------继承extends
    • 类和接口------------------实现implements
  3. 设计规则:
    • 将所有派生类所共有的属性和行为,抽到超类中---------------抽共性
    • 若对象的行为都一样,设计为普通方法
      若对象的行为不一样,设计为抽象方法
    • 将部分派生类所共有的属性和行为,抽到接口中
      接口是对继承的单根性的扩展---------------------------实现多继承
  4. 接口的意义:
    • 实现多继承
    • 制定了一套标准、规则

你可能感兴趣的:(CGB2202,java)