MATLAB 2017-10-15
关键词:重载、继承、多态、static、final、抽象类
继承:面向父类编程。
多态:根据实际对象类型而不是变量类型来调用相应的方法。
故事:
主题-网上商城购物
某人在网上商场通过网上商场的电子商务网站浏览
商品,看到了喜欢的商品,点击
查看商品的详情,确认这是想要购买的商品后,登陆
自己的账户,点击加入购物车,进入购物车页面中点击购买
,填写
收货人姓名、收货人电话和收货人地址以及支付方式,确认支付
货款,完成网上购物活动。
类图:
可选:团队协作可使用git与码云。在码云中新建项目。所有队员都应在码云中该项目下均应有有提交记录。截图你们的提交记录。
关键代码:
package shopping; class goods{//商品详情 private String name;//商品名 private int price;//价格 public goods(String name, int price) { super(); this.name = name; this.price = price; } @Override public String toString() { return "goods [name=" + name + ", price=" + price + "]"; } } class user{//账户 private String name;//账户名称 private String pay;//支付方式 public user(String name, String pay) { super(); this.name = name; this.pay = pay; } @Override public String toString() { return "user [name=" + name + ", pay=" + pay + "]"; } } class consignee extends user{//收货人 private String name;//收货人姓名 private String number;//收货人电话 private String address;//收货人地址 public consignee(String name, String pay, String name2, String number, String address) { super(name, pay); name = name2; this.number = number; this.address = address; } @Override public String toString() { return "consignee [name=" + name + ", number=" + number + ", address=" + address + "]"; } } class shopcart extends user{public shopcart(String name, String pay) {//购物车 super(name, pay); } private String name;//购物车里的商品 private String number;//各个商品数量 private String price;//各个商品的价格 private String amount;//商品总数 private String totalprices;//商品总价 public shopcart(String name, String pay, String name2, String number, String price, String amount, String totalprices) { super(name, pay); name = name2; this.number = number; this.price = price; this.amount = amount; this.totalprices = totalprices; } @Override public String toString() { return "shopcart [name=" + name + ", number=" + number + ", price=" + price + ", amount=" + amount + ", totalprices=" + totalprices + "]"; } } public class Shopping { public static void main(String[] args) { // TODO Auto-generated method stub } }
提交记录:
不知道怎么在同一个项目下提交。。
就先截一下队友提交的记录吧。。。
分析ManagerTest.zip中的代码,回答几个问题:
继承关系:> Manager extends Employee
共有方法: String getName()、 double getSalary()、Date getHireDay()、void raiseSalary(double byPercent)
子类特有属性和方法: private double bonus、void setBonus(double b)、 Manager(String n, double s, int year, int month, int day)、double getSalary()
答:jvm会根据实际对象类型
来调用方法,调用的应该是Employee类
的getSalary方法。
好处:父类的方法,以后需要新的子类也可以继续调用父类的方法。
原因:这题不太会,个人感觉就是这样以后每个需要用到父类方法的都复制粘贴,感觉代码就会很多,程序看起来更复杂了。
答:其实还是用了父类的方法,代码还是在。
代码展示:
public String toString() { return super.toString()+"Fruit [name=" + name + "]"; }
基本采用的都是自动生成
代码:
@Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((name == null) ? 0 : name.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Fruit other = (Fruit) obj; if (name == null) { if (other.name != null) return false; } else if (!name.equals(other.name)) return false; return true; } }
代码:
public class Main { public static void main(String[] args) { Fruit a= new Fruit(); Fruit b= new Fruit(); a.setName("Happy"); b.setName("happy"); System.out.println(a.equal(b)); } }
结果:
提示:直接使用ArrayList的contains方法实现判断对象是否存在。
测试代码:(已参考同学代码,自己打的程序崩了)
public class Main { public static void main(String[] args) { Scanner in=new Scanner(System.in); ArrayList<Fruit> fruitList=new ArrayList<>(); while(true) { String a=in.next(); if(a.equals("end")) break; Fruit s1=new Fruit(a); if(!fruitList.contains(s1)) { fruitList.add(new Fruit(a)); } } System.out.println(fruitList.size()); for(Fruit e :fruitList ) { System.out.println(e.name); } } }
测试结果:
ArrayList的contains代码与equals方法的关系:
查看了contains的源代码:
public boolean contains(Object o) { return indexOf(o) >= 0; } public int indexOf(Object o) { if (o == null) { for (int i = 0; i < size; i++) if (elementData[i]==null) return i; } else { for (int i = 0; i < size; i++) if (o.equals(elementData[i])) return i; } return -1; } public boolean equals(Object obj) { return (this == obj); }
可以发现如果对象不为null的话,最终是调用的Object类的equals()方法
。
总结:本题实验课上老师有讲过一些部分,关键是在输出这一块,解决对我来说有点困难,后面都是问舍友帮我解决的。
好处:子类中同样有父类中的getPerimeter()、getArea(),但是子类中另外编写了实现这个方法的不同代码,多态使一种方法有多种实现形式。
总结:ArrayList操作动态变化很便捷,但是我用的不多,代码显得很长,慢慢的学习吧。。。
注意:
1、自反性:对于任何非空引用x,x.equals(x)应该返回true。
2、对称性:对于任何引用x和y,如果x.equals(y)返回true,那么y.equals(x)也应该返回true。
3、传递性:对于任何引用x、y和z,如果x.equals(y)返回true,y.equals(z)返回true,那么x.equals(z)也应该返回true。
4、一致性:如果x和y引用的对象没有发生变化,那么反复调用x.equals(y)应该返回同样的结果。
5、非空性:对于任意非空引用x,x.equals(null)应该返回false。
程序填空:感觉跟后面做的继承那一题里面写的函数有点像,就直接放下去了。。
函数题:
6-1:先创建一个新对象,然后返回。但是提交PTA一直提示内部错误。。。
6-2:本题根据输入的字母,依次选择对应的情况即可。一开始我忘记了加上为null情况,导致答案错误,后来加上去后就可以了。
6-3:equals先做了自动生成,但是后面的程序我就不太会写了,后来是和舍友讨论以后才得出的正确答案。
题目集:[jmu-Java-03-面向对象1-基础-封装继承]
上周已经做了前几题的提交
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
本周完成(形状-继承,覆盖)
需要有两张图(1. 排名。2.PTA提交列表)
排名:
PTA提交列表:
需要将每周的代码统计情况融合到一张表中
周数 | 行数 | 新增行数 | 文件数 | 新增文件数 |
---|---|---|---|---|
1 | 57 | 57 | 5027 | 5027 |
2 | 400 | 400 | 10 | 10 |
3 | 508 | 508 | 23 | 13 |
5 | 609 | 609 | 31 | 8 |