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


    Java第五次作业

    面向对象高级特性(抽象类与接口)

    (一)学习总结

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

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

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

    不能够编译成功。

    在接口中的抽象方法必须定义为public访问权限。子类中必须覆写接口中的全部方法。

    程序修改:

    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 runing");
    		
    	}
    }
    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 runing
    

    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 Ha{
        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]);
            }
        }
    }
    

    输出结果:

    peach
    orange
    banana
    apple
    

    5.其他需要总结的内容。

    (二)实验总结

    程序设计思路:创建MusicBox接口,据此接口定义出具体的子类PianoBox和ViolinBox,创建工厂Factory类为对象实例化,利用测试类输出。

    (1).程序设计思路:用java.util.Date类表示职工的生日和参加工作时间。在测试类中创建匿名日期类对象,创建Comparable接口实现对生日的排序,利用循环输出。

    (2).程序设计思路:用java.util.Date类表示职工的生日和参加工作时间,在职工类下创建class ZhiComparator implements Comparator,Comparator接口为补救型接口,进行z1与z2之间的排序。用SimpleDateFormat定义一个日期的模板:"yyyy-mm-dd",再把字符串数组利用SimpleDateFormat转成日期类数组,分别赋给每一个员工,利用循环输出。

    程序设计思路:创建宠物接口,据此接口定义出具体的子类Dog和Cat,在测试类中定义Dog和Cat的对象数组,利用循环寻找符合条件的宠物。

    问题:实际运行当中出现了数组下标越界

    解决方式:重新定义数组数值

    (三)代码托管

    作业链接

  • 相关阅读:
    Visual Studio 中的 .NET Framework 类库
    泛型
    泛型
    事件
    基于事件的异步模式
    使用委托进行异步编程
    使用 IAsyncResult 调用异步方法
    异步编程设计模式
    演练:使用VS2010 C# 创作简单的多线程组件
    [转][MEF插件式开发] 一个简单的例子
  • 原文地址:https://www.cnblogs.com/renxiuxing/p/6761960.html
Copyright © 2020-2023  润新知