Week04-面向对象设计与继承

1. 本周学习总结

1.1 写出你认为本周学习中比较重要的知识点关键词

重载 static final 抽象类 继承与多态

1.2 尝试使用思维导图将这些关键词组织起来。注:思维导图一般不需要出现过多的字。

1122356-20171011175801809-2096886785.png

2. 书面作业

1. 面向对象设计

1.1 讲故事:用50字以上讲一个你在网上商城购物或者在班级博客进行学习的故事。使用Markdown的加粗标记把关键名词标注出来,使用语句块标记把里面关键的动词标注出来。讲故事范例:见参考资料UML类图中如何绘制类图

我想要在淘宝上买一盒饼干,先在淘宝中搜索饼干类,然后货比三家,比较价格和好评度,挑选自己喜欢的加入购物车,在购物车结算价格,然后发现买多了,删掉不要的,结算付钱。

1.2 找出系统中包含的类及其属性、方法,类与类之间的关系,并绘制相应类图。注意:不一定非要体现继承关系。只要能将系统描述完整即可。一开始设计的时候不要考虑太多,不要出现太多的类,仅出现必要的类,完成最小功能即可。对商城购物系统建议只做购物车模块。

1122356-20171012214027918-1490876793.png

1.3 使用Java代码实现这个系统(不必很完善)。粘贴运行截图与关键代码。将来要在这个基础上逐渐完善、扩展成一个完整的面向对象的系统。合作完成:2-3人一个小组。

import java.util.Collection;  
import java.util.Iterator;  
import java.util.LinkedHashMap;  
import java.util.Map;  
public class ShoppingCart {//购物车  
    //key:商品编号 value:商品条目  
    private Map<Integer,ProductItem> map=new LinkedHashMap<Integer,ProductItem>();  
      
    public void addProduct(Product p){//添加商品  
        int productId=p.getProductId();  
        if(map.containsKey(productId)){  
            ProductItem productItem=map.get(productId);  
            productItem.setCount(productItem.getCount()+1);  
        }else{  
            map.put(productId, new ProductItem(p,1));  
        }  
    }  
    public void showAll(){//查看订单信息  
        Collection<ProductItem> productItems = map.values();  
        Iterator<ProductItem> iterator = productItems.iterator();  
        while(iterator.hasNext()){  
            ProductItem productItem = iterator.next();  
            Product product = productItem.getProduct();  
            System.out.println("商品编号:"+product.getProductId()+",商品名称:"  
            +product.getProductName()+",单价:"+product.getPrice()+",数量:"+productItem.getCount()  
            +",小计:"+productItem.totalMoney());  
        }  
    }  
    public boolean deleteProduct(int productId){//删除商品  
        if(map.containsKey(productId)){  
            map.remove(productId);  
            return true;  
        }  
        return false;  
    }  
    public boolean modifyProduct(int productId,int count){//修改  
        if(map.containsKey(productId)){  
            if(count>=1){  
                ProductItem productItem = map.get(productId);  
                productItem.setCount(count);  
                return true;  
            }else if(count==0){//删除该商品  
                deleteProduct(productId);  
                return true;  
            }     
        }  
        return false;  
    }  
      
    public void clearCart(){//清空购物车  
        map.clear();  
    }  
      
    public double totalAllMoney(){//商品总钱数  
        double total=0;  
        Collection<ProductItem> productItems = map.values();  
        Iterator<ProductItem> iterator = productItems.iterator();  
        while(iterator.hasNext()){  
            ProductItem productItem = iterator.next();  
            double money=productItem.totalMoney();  
            total+=money;  
        }  
        return total;  
    }  
}  

2. ManagerTest.zip代码分析(继承、多态)

2.1 简述文件中表现出的继承关系。哪些是共有方法,哪些是子类特有的属性和方法?

Manager中使用的("Carl Cracker", 80000, 1987, 12, 15)从父类Employee中获得name等属性,所有面向父类型的代码均适用于其子类

继承用extends关键字,extends后面的类则表示父类,extends前面的类则是子类。在java中所有的类都默认继承Object类,Object类是所有类的父类。

2.2 文件第26行e.getSalary(),到底是调用Manager类的还是Employee类的getSalary方法?

第一个e是调用Manager类,之后e是调用Employee类

2.3 Manager类的构造函数使用super调用父类的构造函数实现了代码复用,这样有什么好处?为什么不把父类构造函数中的相关代码复制粘贴到Manager的构造函数中,这样看起来不是更直观吗?

代码复用可以提高软件开发的效率,减少代码量;复制粘贴虽然直观但也增加了代码量,无形中增加了阅读难度。

3. Object类中的toString与equals

3.1 编写Fruit类,属性String name。如果覆盖其toString()方法,其父类中的toString方法的代码就没有了吗?编写Fruit的toString()方法,在该方法中要将调用父类的toString方法得到的字符串与自己特有的属性name拼接起来,怎么编写?(使用代码展示)

class CCCC{
    int i=0;
    public String toString(){
        return String.valueOf(i)+":"+super.toString();
    }
}

3.2 为Fruit类编写equals方法覆盖父类相应方法,功能为当两个Fruit对象name相同时(忽略大小写),返回true。(使用代码证明你自己覆盖的equals方法是正确的)

package PTA3;

import java.util.Scanner;

class Fruit extends Object{
    public boolean equals(String name1,String name2)
    {
        if(name1.equals(name2)) return true;
        else return false;
    }   
}
public class fruit {

    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        String name1=sc.nextLine();
        String name2=sc.nextLine();
        System.out.println(name1.equals(name2));
    }
}

1122356-20171014130233637-138300237.png

3.3 完成3.2后,使用ArrayList fruitList存储多个fruit,添加时要求如果要添加的fruit对象在fruitList中已存在就不添加,不存在就添加。编写相关测试代码。并分析ArrayList的contains代码与equals方法有何关系?

package PTA3;
import java.util.ArrayList;
import java.util.Scanner;
public class Main(6) {
 public static void main(String[] arge){
 Scanner input = new Scanner(System.in);
 ArrayList<Fruit> Fruits = new ArrayList<Fruit>();
 int n= input.nextInt();
 Fruit[] fruits = new Fruit[n];
 for(int i=0;i<n;i++){
     fruits[i] = new Fruit(input.next());
     
 }
 for(int i=0;i<fruit.length;i++){
     if(!Fruits.contains(fruits[i])){
         Fruits.add(fruits[i]);
     }
 }
 System.err.println("所有:");
 for (Fruit fruit : Fruits){
     System.out.println(fruit.getName());
 }
 }
}

1122356-20171014133424777-605077842.png

4. 实验总结:

4.1 PTA编程题(形状-继承)。并回答:在本题中使用多态为编程带来了什么好处。

  • 不用为每一个类编写功能调用,只需对抽象类进行处理,提高程序可复用性
  • 派生类的功能可以被基类的方法或引用变量调用,提高可扩充性、可维护性

4.2 PTA编程题(覆盖)。并回答:编写eqauls方法是需要注意些什么?

Java语言规范对equals方法的要求:

  • 自反性,对于任何非控引用x,x.equals(x)都应该返回true。
  • 对称性,对于任何引用x和y,如果x.equals(y)返回true,那么y.equals(x)也应该返回true。
  • 传递性,如果x.equals(y),y.equals(z)都返回true,那么,x.equals(z)返回true。
  • 一致性,如果x和y引用的对象没有发生变化,那么无论调用多少次x.equals(y)都返回相同的结果。
  • 对于任意非空引用x,x.equals(null)都应该返回false。

4.3 程序填空、函数题(1-3)。

程序填空:
使用this调用已有构造函数
6-1:
使用super调用父类对象
6-2
建立终极父类,逐个实现题目要求
6-3
覆盖Employee类的equals,注意company为null的情况,如果均为null返回true

3. 码云及PTA

3.1. 码云代码提交记录

1122356-20171014134948668-1167083212.png

3.2 截图PTA题集完成情况图

1122356-20171014135012402-1068211194.png
1122356-20171014135039715-500110241.png
1122356-20171014135058668-1053781661.png

3.3 统计本周完成的代码量

1122356-20171014140053527-1779414632.png

行数新增行数文件数新增文件数
894182519

转载于:https://www.cnblogs.com/201621123065guo/p/7651037.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值