201621123018《Java程序设计》第4周学习报告
1. 本周学习总结
1.1 写出你认为本周学习中比较重要的知识点关键词
继承、多态、子类、父类、抽象类、abstract、super、object
1.2 尝试使用思维导图将这些关键词组织起来。注:思维导图一般不需要出现过多的字。

1.3 可选:使用常规方法总结其他上课内容。
本周主要学习了继承与多态,多态即为同一种表现,多种实现,比如面积为一种表现,圆的面积,长方形的面积,三角形的面积等等为多种表现。继承即子类继承并可以调用父类的方法和变量避免了不同类之间共同属性的重复描述。
2. 书面作业
1. 面向对象设计(大作业1-该作业将作为以后其他作业的基础,请务必完成)
1.1 讲故事:用50字以上讲一个你在网上商城购物或者在班级博客进行学习的故事。使用Markdown的加粗标记把关键名词标注出来,使用语句块标记把里面关键的动词标注出来。讲故事范例:见参考资料UML类图中如何绘制类图
进入淘宝网,搜索羽绒服,选择所看中的商品,再选择其属性,如尺码,颜色等,加入购物车,筛选完毕后,进入购物车,根据需求更改要购买商品的数目,选择确定要购买的商品进行结算,结算时添加收货地址、联系方式及备注,最后付钱,购买成功。
1.2 找出系统中包含的类及其属性、方法,类与类之间的关系,并绘制相应类图。注意:不一定非要体现继承关系。只要能将系统描述完整即可。一开始设计的时候不要考虑太多,不要出现太多的类,仅出现必要的类,完成最小功能即可。对商城购物系统建议只做购物车模块。

1.3 使用Java代码实现这个系统(不必很完善)。粘贴运行截图与关键代码。将来要在这个基础上逐渐完善、扩展成一个完整的面向对象的系统。合作完成:2-3人一个小组。public class shopping_car {
private Goods[] good;
public Goods[] getGood() {
return good;
}
public void setGood(Goods[] good) {
this.good = good;
}
public void Product_Add(){//添加商品种类
}
public void Product_Delete() {//删除商品
}
public void Count_Add(){//添加某商品数量
}
public void Count_Decreased(){//减少某商品数量
}
public void Clear_shoppingcar(){//清空购物车
}
public double Total_price(){//计算商品总价格
}
}
}
2. ManagerTest.zip代码分析(继承、多态)
2.1 简述文件中表现出的继承关系。哪些是共有方法,哪些是子类特有的属性和方法?
共有的方法:getSalary()
子类特有的属性和方法:属性:private double bonus,方法:setBonus()
2.2 文件第26行e.getSalary(),到底是调用Manager类的还是Employee类的getSalary方法?
因为e为Employee类的,所以调用的是Employee类的方法
2.3 Manager类的构造函数使用super调用父类的构造函数实现了代码复用,这样有什么好处?为什么不把父类构造函数中的相关代码复制粘贴到Manager的构造函数中,这样看起来不是更直观吗?
这样可以简化代码,节省空间和时间,提高代码运行效率。
3. Object类中的toString与equals
3.1 编写Fruit类,属性String name。如果覆盖其toString()方法,其父类中的toString方法的代码就没有了吗?编写Fruit的toString()方法,在该方法中要将调用父类的toString方法得到的字符串与自己特有的属性name拼接起来,怎么编写?(使用代码展示)
父类的方法的代码不会没有。
package weekfour;
pblic class Main {
public static void main(String[] args){
System.out.println(new Fruit());
}
}
class Fruit{
public String name;
@Override
public String toString() {
return name+"-"+super.toString();
}
}

3.2 为Fruit类编写equals方法覆盖父类相应方法,功能为当两个Fruit对象name相同时(忽略大小写),返回true。(使用代码证明你自己覆盖的equals方法是正确的)
package weekfour;
public class Main {
public static void main(String[] args) {
Fruit a=new Fruit("APPLE");
Fruit b=new Fruit("apple");
Fruit c=new Fruit("orange");
System.out.println(a.equals(b));
System.out.println(a.equals(c));
}
}
lass Fruit{
String name;
public Fruit(String name){
this.name=name;
}
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.equalsIgnoreCase(other.name))
return false;
return true;
}
}

3.3 完成3.2后,使用ArrayList<Fruit> fruitList存储多个fruit,添加时要求如果要添加的fruit对象在fruitList中已存在就不添加,不存在就添加。编写相关测试代码。并分析ArrayList的contains代码与equals方法有何关系?
public class fruit1 {
public static void main(String[] args) {
ArrayList<Fruit> fruitList = new ArrayList<Fruit>();
Fruit[] fruit = new Fruit[5];
fruit[0] = new Fruit("APPLE");
fruit[1] = new Fruit("apple");
fruit[2] = new Fruit("MELON");
fruit[3] = new Fruit("melon");
fruit[4] = new Fruit("orange");
for(int i=0;i<fruit.length;i++){
if(fruitList.contains(fruit[i])==false)
fruitList.add(fruit[i]);
}
for(int j=0;j<fruitList.size();j++){
System.out.println(fruitList.get(j));
}
}
}

4. 实验总结:
4.1 PTA编程题(形状-继承)。并回答:在本题中使用多态为编程带来了什么好处。
本题要记得在输入后加个in.nextLine()来吃掉回车。PI是要定义在Shape类中。
好处:本题要求圆和长方形的总面积,常规的做法是求出圆和长方形的面积,在编写方法将他们想加起来,如果在加一个三角形的面积,这个方法就要重新编写。使用多态则不必修改求总面积的方法。
4.2 PTA编程题(覆盖)。并回答:编写eqauls方法是需要注意些什么?
使用eqauls方法时特别要注意空指针,例如:
if(persons2[j].equals(name, age, gender))
这种写法就会出现空指针的错误,应该改成这种写法
if("name, age, gender".equals(persons2[j]))
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。
4.3 程序填空、函数题(1-3)。
- 程序填空:使用this(),重写toString()
- 6-1:重写toString()方法,用
super来调用父类的方法 - 6-2:
object是所有类的父类,本题建一个object数组就可以完成 - 6-3本题使用eclipse自动生成再修改即可
3. 码云及PTA
3.1. 码云代码提交记录

3.2 截图PTA题集完成情况图



3.3 统计本周完成的代码量
| 周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
|---|---|---|---|---|
| 1 | 160 | 160 | 49 | 49 |
| 2 | 387 | 227 | 6 | 55 |
| 3 | 630 | 243 | 4 | 59 |
| 4 | 968 | 238 | 5 | 65 |
201621123018《Java程序设计》第4周学习报告的更多相关文章
- 20145326《Java程序设计》第一周学习总结
20145326<Java程序设计>第一周学习总结 教材学习内容总结 转眼间新的一学期终于开始了!为什么我这么期待呢?因为这学期可以上娄嘉鹏老师的java程序设计课,我不是什么电脑天才,之 ...
- 20155328 2016-2017-2 《Java程序设计》第九周学习总结
20155328 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 16.1 JDBC入门 JDBC是Java联机数据库的标准规范,定义一组标准类与接口,应用程 ...
- 20155319 2016-2017-2 《Java程序设计》第一周学习总结
20155319 2016-2007-2 <Java程序设计>第一周学习总结 考核方式 翻转课堂考核12次(5*12=60):每次考试20-30道题目,考试成绩规格化成5分(如总分20分就 ...
- 20145213《Java程序设计》第九周学习总结
20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...
- 20145213《Java程序设计》第二周学习总结
20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...
- 20145213《Java程序设计》第一周学习总结
20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...
- 21045308刘昊阳 《Java程序设计》第九周学习总结
21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...
- 20145330孙文馨 《Java程序设计》第一周学习总结
20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...
- 20145337 《Java程序设计》第九周学习总结
20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...
- 20145337 《Java程序设计》第二周学习总结
20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...
随机推荐
- 搭建事务管理转账案例的环境(强调:简化开发,以后DAO可以继承JdbcDaoSupport类)
1. 步骤一:创建WEB工程,引入需要的jar包 * IOC的6个包 * AOP的4个包 * C3P0的1个包 * MySQL的驱动包 * JDBC目标2个包 * 整合JUnit测试包2.步骤二:创建 ...
- MacOs安装mysql与修改root密码
1.下载安装包 http://www.mysql.com/downloads/ 找到如下内容下载 mysql-5.7.21-1-macos10.13-x86_64.dmg下载地址是 https://c ...
- 全基因组测序 从头测序(de novo sequencing) 重测序(re-sequencing)
全基因组测序 全基因组测序分为从头测序(de novo sequencing)和重测序(re-sequencing). 从头测序(de novo)不需要任何参考基因组信息即可对某个物种的基因组进行测序 ...
- DNA甲基化检测服务
DNA甲基化检测服务 DNA甲基化是最早发现的基因表观修饰方式之一,真核生物中的甲基化仅发生于胞嘧啶,即在DNA甲基化转移酶(DNMTs)的作用下使CpG二核苷酸5'-端的胞嘧啶转变为5'-甲基胞嘧啶 ...
- 2015湖南湘潭 D 二分
2015湖南湘潭第七届大学生程序设计比赛 D题 Fraction Accepted : 133 Submit : 892 Time Limit : 1000 MS Memory Limit : ...
- window.location.origin
当前页面的域名+端口号 var HTTP_REMOTE = (function () { var origin = window.location.origin; if (origin.match(/ ...
- Mockplus是如何节省你的原型时间的?
还在用老牌原型工具一点点绘制产品原型吗?还在为实现一个满意的交互而绞尽脑汁吗?还在为无法和用户高效沟通而发愁吗?朋友,现在是快速原型的时代了.时间不等人,当你精雕细琢完成产品启动页的时候,别人的原型已 ...
- canvas标签的基本用法
1.canvas和其他标签一样使用,但是IE8以下是不支持的,可以在canvas里面加一个span用来提示,例如: <canvas> <span>IE8不支持canvas< ...
- list集合如何对里面的元素进行排序
Collections 是集合的公共类,提供各种工具,其中提供了排序方法. Collections.sort(),方法两个参数,1,要排序的集合,2.排序方式 下面是匿名内部类,实现了排序借口,你也可 ...
- 2018.09.25 bzoj3572: [Hnoi2014]世界树(虚树+树形dp)
传送门 虚树入门题? 好难啊. 在学习别人的写法之后终于过了. 这道题dp方程很好想. 主要是不好写. 简要说说思路吧. 显然最优值只能够从子树和父亲转移过来. 于是我们先dfs一遍用儿子更新父亲,然 ...