zoukankan      html  css  js  c++  java
  • 201521123074 《Java程序设计》第5周学习总结

    1、本周学习总结

    1.1 尝试使用思维导图总结有关多态与接口的知识点

    1.2 可选:使用常规方法总结其他上课内容。

    • 接口定义了解:接口(interface)就是方法声明和常量值的集合。
    • 几种接口讲解:Comparable接口、Comparator接口。
    • 几种关系理解:接口、多态性、继承、抽象类。


    #2、书面作业

    Q1、代码阅读:Child压缩包内源代码

    1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误。并分析输出结果。
    A

    • 编译不通过。错误如下。【访问不了父类的这个变量。】
    • 改正方法一:将父类的i变量由private修饰改为用protected修饰。
      原因:private只有类本身自己可以访问。protected子类可以访问(即使不在同一个包)同包的其他类也可以访问父类的protected属性和方法。
    • 改正方法二:创建父类中i的setter及getter方法。
    • 分析输出结果。输出结果为1 2 2 1 1 2 1(实际每个数字间有换行)
      前五个数字1 2 2 1 1均是因为Chlid类继承了Parent类,而其自身类里也没有对i,j的重新操作,所以用super或是没用,都是输出父类的对i,j的定义。
      后两个2 1是因为Other类的showParentj方法将parent类的对象p作为一个参数,因为parent类的对象和方法都是protected修饰的,能被访问即输出。

    1.2 另外一个包中的OutOfParentPackage.java,能否编译通过?提示什么错误?分析原因。
    A:

    • 编译不能通过。错误原因:【The type Parent is not visible】下如图所示。
    • 分析原因:因为Parent类及放在了OutOfParentPackage类不在同一个包中,但是com.parent包中的parent类没有任何修饰,默认是default,即只允许在同一个包中进行访问。import 仅仅只是声明当前class需要引用到import的类。在编译时仅仅检查是否有这些类,当前class在需要调用这些类里面方法是否都存在。在此题中因为parent是不给别的包访问的,所以报错。

    **1.3** 回答:如果为了访问到`protected`修饰的属性或方法应该怎么办? **A:** protected关键字,子类可以访问(即使不在同一个包),同包的其他类可以访问父类的protected属性和方法。所以,可以让类与类呈现继承关系或者类与类放在同一个包中。

    Q2、abstract进阶:阅读GuessGame抽象类的设计与使用源代码

    2.1 Guess改造前代码很简单,而改造后的代码使用了抽象类、抽象方法看起来很复杂,那这样的改造到底有什么好处呢?
    A:

    改造前,未使用抽象类,只能控制台输出。改造后,使用抽象类,可以在控制台,也可以使用对话框图形界面等输入。(ps:引用自文件名)


    2.2 如果想将该游戏改造成图形界面,应该进行一些什么操作? **A:** 设计图形界面的类继承抽象类,重写抽象方法支持图形界面的输入输出。
    2.3 结合该例子,你觉得什么时候应该使用`abstract`? **A:** 结合该例子,我认为应该在需要在不同环境实现时用abstract。比如用需要在命令台、控制台、图形界面等不同的环境实现输入。
    2.4 重要:在这个例子中,变化的是什么,不变的是什么?尝试结合abstract、继承等概念进行说明。 **A:** 不变的是这个猜数字游戏的本质实现,变化的是输入方法的抽象。ConsoleGame类`继承`GuessGame抽象类,得以实现了它的抽象方法。

    Q3、Comparable与Comparator

    3.1 描述Comparable接口的用途。为什么某个类实现了Comparable接口就可以直接使用Arrays.sort对其进行排序?
    A: 此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序。 对实现此接口的对象列表(和数组)可以通过Collections.sort或Arrays.sort进行自动排序。


    3.2 有了Comparable接口为什么还需要Comparator接口呢?
    A: 因为Comparable接口强制进行自然排序,而Comparator接口不强制进行自然排序,可以指定排序顺序。

    Arrays.sort可以对所有实现Comparable的对象进行排序。但如果有多种排序需求,如有时候需对name进行降序排序,有时候只需要对年龄进行排序。使用Comparable无法满足这样的需求。但是可以编写不同的Comparator来满足多样的排序需求。(摘自PTA 5-2实验)



    Q4、面向接口案例分析
    阅读Case-StudentDao.zip案例

    4.1 画出类关系图,描述每个类与接口的作用。
    A:

    • student类:呈现关于学生的各种属性。
    • StudentDao接口:提供writeStudent写学生信息readStudent读学生信息diplayAllStudent展示所有学生信息。这三个抽象方法。
    • StudentDaoArrayImpl类:用数组来存放学生信息,具体实现接口的三个抽象方法。
    • StudenDaoListImpl类:用列表来存放学生信息,具体实现接口的三个抽象方法。
    • Test类:包含主函数,实现各种输入输出。

    **4.2** StudenDaoListImpl与StudentDaoArrayImpl有何区别? **A:** 区别在于:使用的数据结构不同。StudentDaoArrayImpl类用**数组**来存放学生信息。StudenDaoListImpl类用**列表**来存放学生信息。

    Q5、什么是面向接口编程?面向接口编程的好处是什么?
    结合题目3与4中的Test.java的代码讨论分析。不要百度原封不动照搬!

    A: 面向接口编程就是在变成中运用接口,寻找到类与类之间的联系,大概理解成一个框架,框架里的东西可以具体类里实现。好处:如第三题的Comparble接口,就是一种比较能力,一个类不能继承很多类,但是可以实现很多接口,拥有很多能力。还有第四题的StudentDao接口为类提供了三种抽象方法,StudentDaoArrayImpl类及StudenDaoListImpl类都能实现这个接口,用自己不同的数据结构实现他们大致类似的抽象方法。



    Q6、结对编程:面向对象设计(大作业2-非常重要)
    A:
    6.1

    顾芷菱 柯智青
    http://www.cnblogs.com/guzhiling http://www.cnblogs.com/kzq-java-markdown/

    6.2 常用功能描述框架图

    6.3 关键代码

    //Stuff类
    class Stuff {
    	public String Name;
    	public int Price;
    	public String Size;
    	public int Num;
    	public String Color;
    
    	public static void show(Stuff[] stuff) {
    		for (int i = 0; i < stuff.length; i++) {
    			System.out.println(stuff[i].toString());
    		}
    
    	}
    
    	@Override
    	public String toString() {
    		return "Name=" + Name + ", Price=" + Price + ", Size=" + Size
    				+ ", Num=" + Num + ", Color=" + Color;
    	}
    
    	public Stuff(String name, int price, String size, int num, String color) {
    		super();
    		Name = name;
    		Price = price;
    		Size = size;
    		Num = num;
    		Color = color;
    	}
    
    	public static Stuff search(String x, Stuff[] stuff) {
    		for (int i = 0; i < 5; i++) {
    			if (stuff[i].Name.equals(x)) {
    				return stuff[i];
    			}
    		}
    		return null;
    	}
    }
    //ShoppingCart类
    class ShoppingCart {
       ArrayList<Stuff> shoppingList=new ArrayList<Stuff>();
       ArrayList<Stuff>purchaseList=new ArrayList<Stuff>();
       public void add(Stuff e){
    	   shoppingList.add(e);
       }
       public void delete(Stuff e){
    	   shoppingList.remove(e);
       }
       public void clear(){
    	   if(shoppingList.size()!=0){
    		   shoppingList.clear();
    	   }
       }
       public void display(){
    	   if(shoppingList.size()==0){
    		   System.out.println("您的购物车中空荡荡的");
    	   }
    	   else{
    		   for (int i = 0; i <shoppingList.size(); i++) {
    			System.out.println(shoppingList.get(i));
    		}
    	   }
       }
       public void setpurchaseList(Stuff e){
    	   purchaseList.add(e);
       }
       public void totalPrice(){
    	   double sum=0;
    	   for(int i=0;i<purchaseList.size();i++){
             sum+=purchaseList.get(i).Price*purchaseList.get(i).Num;
    	   }
    	   System.out.println("总计为"+sum+"元");
       }
    
    }
    //User类
    public class User {
     private String name;
     private String address;
     private String tel;
    
    public void show() {
    	System.out.println(name+" "+tel+" "+address);
    }
    public User(String name, String address,String tel) {
    //	super();
    	this.name = name;
    	this.address = address;
    	this.tel = tel;
    }
    }
    
    

    6.4 运行界面




    3. 码云代码提交记录

    在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图



    4. PTA实验

    题目集:jmu-Java-03-面向对象1-基础-封装继承 中的
    函数(4-1, 4-2, 4-3,4-4较难选做)
    编程(5-4, 5-5, 5-6)
    一定要有实验总结

    • 5-1:课堂上完成的。初步认识了Comparable接口的使用。
    • 如果要按照升序排序,
      则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)
      如果要按照降序排序
      则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)

  • 相关阅读:
    浙江省CIO协会钱塘江论坛近日在网易云创沙龙宣布成立
    用Python解析XMind
    Flask写web时cookie的处理
    一篇文章看懂Facebook和新浪微博的智能FEED
    改进网易云音乐的“音乐社交”构想
    移动端爬虫工具与方法介绍
    用供应链管理思路降低教培产品成本
    【网易严选】iOS持续集成打包(Jenkins+fastlane+nginx)
    网易严选的wkwebview测试之路
    linux多进程之间的文件锁
  • 原文地址:https://www.cnblogs.com/guzhiling/p/6617545.html
Copyright © 2011-2022 走看看