Java第五次作业--面向对象高级特性(抽象类与接口)

(一)学习总结

1.在上周完成的思维导图基础上,补充本周的学习内容,对Java面向对象编程的知识点做一个全面的总结。

2.汽车租赁公司,出租汽车种类有客车、货车和皮卡三种,每辆汽车除了具有编号、名称、租金三个基本属性之外,客车有载客量,货车有载货量,皮卡则同时具有载客量和载货量。用面向对象编程思想分析上述问题,将其表示成合适的类、抽象类或接口,说明设计思路并画出类图。

  • 设计思路
    将汽车租赁公司设计为抽象类 Company
    客车、货车、皮卡分别设计为Kc、Hc、Pk三个子类继承抽象类Company
    设计接口 Zk 载客接口包含显示载客数方法和 Zh 载货接口包含显示载货数方法
  • 类图

3.阅读下面程序,分析代码是否能编译通过,如果不能,说明原因,并进行改正。如果能,列出运行结果

    interface Animal{    
        void breathe();
        void run();
        void eat();
    }
    class Dog implements Animal{
        public void breathe(){
            System.out.println("I'm breathing");
        }
        void eat(){
            System.out.println("I'm eating");
        }
    }
    public class Test{
        public static void main(String[] args){
            Dog dog = new Dog();
            dog.breathe();
            dog.eat();
        }
    }
  • 不能通过编译
    Dog类继承Animal接口但没有实现接口的抽象方法
  • 修改
interface Animal{    
    void breathe();
    void run();
    void eat();
}
class Dog implements Animal{
    public void breathe(){
        System.out.println("I'm breathing");
    }
    public void eat(){
        System.out.println("I'm eating");
    }
    public void run() {
        System.out.println("I'm running");
        
    }
}
public class Test{
    public static void main(String[] args){
        Dog dog = new Dog();
        dog.breathe();
        dog.eat();
        dog.run();
    }
}
  • 运行结果
    I'm breathing
    I'm eating
    I'm running

4.运行下面的程序

    import java.util.Arrays;
    public class Test{
        public static void main(String[] args){
            String[] fruits = {"peach","banana","orange","apple"};
            Arrays.sort(fruits);
            for(int i = 0;i < fruits.length;i++)
            {
                System.out.println(fruits[i]);
            }
        }
    }

程序输出的结果是升序排序的。查看String 类的源码,说明是如何实现的?如果现在希望对输出的结果进行降序排序,该如何处理?修改上述代码,实现按照字母顺序逆序排序。

  • 运行结果
  • 逆序排序
import java.util.Arrays;
public class Test{
    public static void main(String[] args){
        String[] fruits = {"peach","banana","orange","apple"};
        Arrays.sort(fruits);
        for(int i = fruits.length-1;i >= 0;i--)    
        {
            System.out.println(fruits[i]);
        }
    }
}

(二)实验总结

1.音乐盒的设计

  • 程序设计思路:
    将MusicBox()设计为接口 声明play()方法,再设计两个音乐盒PianoBox和ViolinBox继承接口。
    建立MusicBoxFactory为过渡端,将创建参对象的具体过程隔离起来,达到提高灵活性的目的以产生MusicBox的实例。
  • 问题
    不会建立MusicBoxFactory
  • 解决方案
    参考老师课件

2.Data类和比较器的使用

  • 程序设计思路:
    在之前职工类的基础上 ,利用java.util.Data类表示生日和参加工作时间,在Employee中实现Data类。
    利用比较器来实现按生日大小排序
  • 问题1:
    运用比较器comparator时不能将生日正确进行比较排列.
  • 解决方案1:
    查看文档
  • 问题2:
    Test类的输出时不能输出
  • 解决方案2:
    利用老师所讲try.....catch 方法

3.宠物商店

(三)代码托管

posted @ 2017-04-25 11:00  我爱学习86  阅读(264)  评论(1编辑  收藏  举报