• 《Java技术》第五次作业计科1501赵健宇


    (一)学习总结

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

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

    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();
            }
        }
    
    • 接口Animal中方法都是public abtract,子类Dog需要覆写两个接口的全部抽象方法。
    • 错误提示:Cannot reduce the visibility of the inherited method from Animal,不能减少从动物继承方法的可见性,接口中方法是public abstrat,需要在eat前加public如果不写,方法就是默认的包可见,不是公开方法

    运行结果
    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]);
                }
            }
        }
    

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

    String属于对象,String类继承了comparable接口,使用compareTo方法比较,Arrays中只提供基本数据类型数组排序,其他的都从属于Arrays.sort(Object[])。
    其他的Object类型排序需要对象实现CompareTo接口

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

    ,或使用实现了ComparaTor接口的对象作为Arrays.sort方法的第二个参数.

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

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

    java 中date赋值方法:

    1.通过new对象获取当前的时间复制给date;

     Date date=new Date();
    

    2.通过SimpleDateFormat将字符串转换为date:

    SimpleDateFormat format= new SimpleDateFormat("yyyy年MM月dd HH:mm:ss");
    Date date=format.parse(str);//str表示yyyy年MM月dd HH:mm:ss格式字符串
    

    3.通过Calendar获得date

    Calendar calendar=Calendar.getInstance();
    Date date=calendar.getTime();
    

    (二)实验总结

    实验内容:
    1.某工厂生产各种音乐盒,客户无需知道音乐盒的制作过程,只需知道如何播放音乐盒即可。用简单工厂设计模式实现该过程:接口MusicBox具有方法play(),两个音乐盒类PianoBox,ViolinBox,MusicBoxFactory 产生MusicBox的实例。
    程序设计思路:PianoBox,ViolinBox继承接口musicbox,设计工厂类防止一直修改主方法。
    额外:需要判断工厂类是否返回非空对象

    if(m!=null){
    	m.play();
    }
    

    2.修改第三次作业的第一题,使用java.util.Date类表示职工的生日和参加工作时间,并将职工信息按照生日大小排序后输出。(分别用comparable和comparator实现)

    (1)comparabale

    • woker类继承comparable接口,并覆写comparaTo类
        public int compareTo(Worker o) {
    		if(this.birth.getTime()>o.birth.getTime()){
    			return 1;
    		}else if(this.birth.getTime()<o.birth.getTime()){
    			return -1;
    		}else{
    			return 0;
    		}
    	}
    
    • 主方法中,需要如下方式传Date类
    SimpleDateFormat format= new SimpleDateFormat("yyyy年MM月dd");
    new Worker(10001, "张一 ", "男", format.parse("2010年12月1");
    

    (2)comparator

    • 新增类并继承comparator,覆写compare方法,主方法用sort(数组名,new一个新增类的对象)

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

    问题1:未空指针问题
    原因:设置数组长度
    解决方案:int[] keys = new int[10];判断空时暂停。
    问题2:无法显示购买清单
    原因:宠物商店类的方法传进宠物对象数组,不能判断对象属于哪类
    解决方案:
    使用instanceof关键字,判断哪个子类的实例,下程序如果是cat,则为true

    if (pets[i] != null) {
    	if (pets[i] instanceof Cat) {
    		System.out.println(pets[i].toString());
    		money1 += pets[i].getMoney();
    	}
    }
    

    (二)代码托管

    点击此处进入码云

  • 相关阅读:
    httpd设置HTTPS双向认证
    crossdomain.xml的配置详解
    hibernate中的merge()方法
    解决java.lang.ClassNotFoundException: com.microsoft.sqlserver.jdbc.SQLServerDriver问题
    oracle自定义函数:将使用点分隔符的编码转成层级码格式的编码
    jsp页面科学计数法显示问题的解决办法
    javascript检索某个字符或字符串在源字符串中的位置(下标)
    webwork遍历数组标签
    过多得操作DOM会降低WEB应用的性能
    vue中$refs的用法及作用详解
  • 原文地址:https://www.cnblogs.com/ai1045152332/p/6752360.html
Copyright © 2020-2023  润新知