• Java第五次作业


    (一)学习总结

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

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

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

    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 class Test{
        public static void main(String[] args){
            Dog dog = new Dog();
            dog.breathe();
            dog.eat();
        }
    }
    

    编译不能通过,Dog类继承Animal,Dog类必须实现接口的抽象所有方法,需要添加未实现的方法

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

    运行结果

    apple
    banana
    orange
    peach
    

    程序输出的结果是升序排序的。查看String 类的源码,说明是如何实现的?如果现在希望对输出的结果进行降序排序,该如何处理?修改上述代码,实现按照字母顺序逆序排序。
    String类继承了comparable接口,使用compareTo方法比较,Arrays排序

     public final class String implements java.io.Serializable, Comparable<String>, CharSequence {  //此处继承了comparable接口
          public int compareTo(String anotherString) {   
                int len1 = value.length;
                int len2 = anotherString.value.length;
                int lim = Math.min(len1, len2);
                char v1[] = value;
                char v2[] = anotherString.value;
                int k = 0;
                while (k < lim) {
                    char c1 = v1[k];
                    char c2 = v2[k];
                    if (c1 != c2) {
                        return c1 - c2;
                    }
                    k++;
                }
                return len1 - len2;
         }
    }
    

    逆序排序

    import java.util.Arrays;
    import java.util.Comparator;
    public class Test {
    	public static void main(String[] args) {
    		String[] fruits = { "peach", "banana", "orange", "apple" };
            Arrays.sort(fruits, new Comparator<String>(){
            	public int compare(String o1, String o2){
            		char a = o1.charAt(0);
                    char b = o2.charAt(0);
                    if(o1.equals(o2)){
                        return 0;
                    }else if(a>b){
                        return -1;
                    }else{
                        return 1;
                    }
                }
            });
            for (int i = 0; i < fruits.length; i++) {
                System.out.println(fruits[i]);
            }
        }
    }
    

    运行结果

    peach
    orange
    banana
    Apple
    

    (二)实验总结

    实验内容:
    1.某工厂生产各种音乐盒,客户无需知道音乐盒的制作过程,只需知道如何播放音乐盒即可。用简单工厂设计模式实现该过程:接口MusicBox具有方法play(),两个音乐盒类PianoBox,ViolinBox,MusicBoxFactory 产生MusicBox的实例。

    程序设计思路:
    首先建立MusicBox接口和play()方法,建立PianoBox和ViolinBox两个类,继承MusicBox接口,建立MusicBoxFactory 测试。
    2.修改第三次作业的第一题,使用java.util.Date类表示职工的生日和参加工作时间,并将职工信息按照生日大小排序后输出。(分别用comparable和comparator实现)
    程序设计思路:
    建立Dept类,Employee类,导入Date包,用comparable和comparator比较,在test类中按照生日大小排序输出。
    问题1:运用比较器comparator时date不能正确排列
    原因:两种方法对象不同

    Arrays.sort(emps);
    Arrays.sort(emps,new Employee());
    public int compare(Employee o1,Employee o2){
    	if(o1.equals(o2)){
    		return 0;
    	}
    	else if(o1.birthday.getTime()<o2.birthday.getTime()){
    		return 1;
    	}
    	else{
    		return -1;
    	}
    }
    

    3.在案例宠物商店的基础上,实现以下功能:
    (1)展示所有宠物
    (2)购买宠物
    (3)显示购买清单

    程序设计思路:
    首先建立Pet接口然后建立cat和dog两个类继承Pet接口,建立PetShop写查询和展示方法,在test类中实现用户选择和清单。
    问题1:无法单独计算出猫和狗的总价格
    原因:一个pet数组无法区分
    解决方案:
    定义两个数组分别存放用户选择的猫和狗,分别计算总价格。

    if(no.equals(ps.getPets()[i].getNo())&&i<3){
    							ps.getPets()[i]=(Pet)ps.getPets()[i];
    							System.out.println(ps.getPets()[i].toString());
    							sum1+=ps.getPets()[i].getMoney();
    							c[j]=ps.getPets()[i];
    							j++;
    						}
    						if(no.equals(ps.getPets()[i].getNo())&&i>2){
    							ps.getPets()[i]=(Pet)ps.getPets()[i];
    							System.out.println(ps.getPets()[i].toString());
    							sum2+=ps.getPets()[i].getMoney();
    							d[k]=ps.getPets()[i];
    							k++;
    						}
    

    (三)代码托管

    链接:https://git.oschina.net/hebau_cs15/FMM.git
    码云commit历史截图
    上传实验项目代码到码云,在码云项目中选择“统计-commits”,设置搜索时间段,搜索本周提交历史,并截图。

  • 相关阅读:
    Hadoop3.x完全分布式搭建(详细)
    Golang中使用HTTP连接池及实际案例
    CentOS 7安装Odoo 15社区版的详细操作指南
    PowerDesigner连接实体数据库反向生成物理模型
    nginx配置 外网参考
    Ant Design Vue 使用记载
    SpringBoot启动记录
    cron表达式及生成网站
    ubuntu18.04操作记录
    Vue开发获取input框的值
  • 原文地址:https://www.cnblogs.com/miao0512/p/6754403.html
Copyright © 2020-2023  润新知