zoukankan      html  css  js  c++  java
  • Java第五次作业

    Java第五次作业

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

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

    工具:PowerDesigner
    参考教程:UML 简介
    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();
            }
    }
    

    无法编译 原因是接口中的抽象方法在子类中没有写全,二是void eat()方法前没有写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();
            }
        }
    

    运行结果为:
    I'm breathing
    I'm eating
    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 类的源码,说明是如何实现的?如果现在希望对输出的结果进行降序排序,该如何处理?修改上述代码,实现按照字母顺序逆序排序。
    String类继承了comparable接口,使用compareTo方法比较,Arrays中只提供基本数据类型数组排序,其他的都从属于Arrays.sort(Object[]),对象数组的排序。其他的Object类型排序需要对象实现CompareTo接口,或使用实现了ComparaTor接口的对象作为Arrays.sort方法的第二个参数.(对象数组的比较可以用comparable、Comparator)

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

    (二)实验总结
    实验内容:
    1.某工厂生产各种音乐盒,客户无需知道音乐盒的制作过程,只需知道如何播放音乐盒即可。用简单工厂设计模式实现该过程:接口MusicBox具有方法play(),两个音乐盒类PianoBox,ViolinBox,MusicBoxFactory 产生MusicBox的实例。
    2.修改第三次作业的第一题,使用java.util.Date类表示职工的生日和参加工作时间,并将职工信息按照生日大小排序后输出。(分别用comparable和comparator实现)
    3.在案例宠物商店的基础上,实现以下功能:
    (1)展示所有宠物
    (2)购买宠物
    (3)显示购买清单
    完成实验内容,代码上传到码云,并对完成实验内容过程中遇到的问题、解决方案以及程序的设计思路和思考等进行归纳总结。
    格式如下:
    2、
    程序设计思路:
    把原来的date类删除,通过写就可以了,Test类中会用到try catch,然后用comparable和comparator分别进行排序,其中会用到getTime()方法取出时间进行比较。
    问题1:排序时出不来
    原因:yyyy-mm-dd无法进行比较
    解决方案:需要getTime()方法取出时间进行比较
    3、
    程序设计思路:
    写一个Pet 的接口,然后猫和狗两个类进行实现接口,写一个Petshop宠物商店,宠物商店里通过建立Pet类的对象来和Pet类进行联系,Test类中通过调用宠物商店里的add()方法进行宠物添加,调用宠物商店的查找方法找到顾客要买的宠物,把买了的宠物放在了一个数组里,然后求总价钱。
    问题1:当把买的宠物放入一个数组中,但无法将猫和狗的价钱进行分割
    原因:无法识别Pet类对象不知道是哪个类的实例化。
    解决方案:用关键字instanceof可以判断Pet类对象是哪个类的实例化
    (三)代码托管()
    https://git.oschina.net/hebau_cs15/java-cs01lxy.git

    码云commit历史截图

  • 相关阅读:
    Vue2.0一个login跳转实例
    canvas动画—圆形扩散、运动轨迹
    根据地理信息绘画的html5 小游戏
    用vue开发一个猫眼电影web app
    微信小程序 iphone6 和 iphone6plus 如何设置rpx单位,通俗易懂的方法
    前端实例练习
    为表单加上即时通讯的能力
    MongoDB学习笔记4——GridFS基础
    剑指Offer(Java版)第十三题:请实现一个函数,输入一个整数,输出该数二进制表示中1的个数。
    剑指Offer(Java版)第十一题
  • 原文地址:https://www.cnblogs.com/6770675746-yan/p/6759787.html
Copyright © 2011-2022 走看看