1. 本周学习总结

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

is a关系 覆盖 Object 超级父类 继承 抽象类 多态 重载 static super private public protected default instanceof abstract

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

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

在写形状与继承时我一直被eclipse中的输入问题困住,所以在这里加以总结(假定新建了一个Scanner类的对象sc)
先来看看JDK文档中关于这三个方法的定义:

sc.next()表示查找并返回来自此扫描器的下一个完整标记
sc.nextInt将输入信息的下一个标记扫描为一个 int
sc.nextline()表示此扫描器执行当前行,并返回跳过的输入信息。 此方法返回当前行的其余部分,不包括结尾处的行分隔符。当前位置移至下一行的行首。

sc.next()和sc.nextInt()都是阻塞式的,在遇到空格,Tab,Enter,会继续等待,直到获得相应类型相应的值,而sc.nextline()则是读取包括回车在内的当前行

详细讲解及具体例子请看这篇文章,写的hin好啊!

因此在写代码是最好注意上述三个不要混用,很容易出现错误,最好就是只用一种读取输入的方法比如sc.nextline(),如果要读取一个整数可以再使用Integer.paeseInt转换一下,这样虽然麻烦但是却是不容易出错,如果真的要混用,就要注意实时“吃”掉空格或换行符

2. 书面作业

1. 面向对象设计(大作业1-该作业将作为以后其他作业的基础,请务必完成)

1.1 讲故事:用50字以上讲一个你在网上商城购物或者在班级博客进行学习的故事。使用Markdown的加粗标记把关键名词标注出来,使用语句块标记把里面关键的动词标注出来。

结对对象:靳天婷
今天,我打开淘宝网页,想买一些零食书籍,我直接搜索零食类,出现坚果薯片面包等分类,我每类都点击进去,看了看自己中意的东西,添加购物车,之后我还想买些书来充实自己,于是我又搜索书籍类,出现儿童书教科书课外书等分类,选购了一些再次添加购物车,之后再购物车中结算价格

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

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

abstract class Goods{   //商品类
	protected Books book;
	private Snakes snake;
}
class Books{   //书籍类
	protected double price;
	private String name;
	protected int amount;
	public Books(double price, String name) {
		this.price = price;
		this.name = name;
	}
	public Boolean Add(int amount) {   //添加到购物车
		return true;
	}
	public Boolean Collect(String name) {   //收藏起来
		return true;
	}
	public double sum(Books []books) {     //计算书籍的总价  
		double sum=0.0;
		for(int i=0;i<books.length;i++)
			sum+=books[i].price*books[i].amount;
		return sum;
	}
}
class ChildrenBook extends Books{  //儿童书类继承自书籍类
	public ChildrenBook(double price, String name) {
		super(price,name);
	}
}
class TextBook extends Books{   //教科书类继承自书籍类
	public TextBook(double price, String name) {
		super(price,name);
	}
}
class OutsideReading extends Books{   //课外读物类继承自书籍类
	public OutsideReading(double price, String name) {
		super(price,name);
	}
}
class Snakes{   //零食类
	private double price;
	private String name;
	protected int amount;
	public Snakes(double price, String name) {
		this.price = price;
		this.name = name;
	}
	
	public Boolean Add(int amount) {   //添加到购物车
		return true;
	}
	
	public Boolean Collect(String name) {   //收藏起来
		return true;
	}
	public double sum(Snakes []snakes) {   //计算零食的总价
		double sum=0.0;
		for(int i=0;i<snakes.length;i++)
			sum+=snakes[i].price*snakes[i].amount;
		return sum;
}
}
class Nut extends Snakes{   //坚果类继承自零食类
	public Nut(double price, String name) {
		super(price,name);
	}
}
class Chips extends Snakes{   //薯片类继承自零食类
	public Chips(double price, String name) {
		super(price,name);
	}
}
class Bread extends Snakes{   //面包类继承自零食类
	public Bread(double price, String name) {
		super(price,name);
	}
}
class shoppingcart{    //购物车类
	private double sum=0;
	private Books books;
	private Snakes snakes;
	
	public double AllSum(Goods []goods) {  //计算购物车中所有商品的总价
		double sum=0.0;
		for(int i=0;i<goods.length;i++) 
			sum+=goods[i].sum();
		return sum;
	}
	
	public boolean Delete(ArrayList<Goods> goods) {   //删除购物车中的物品
		return true;
	}
}

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

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

Manager类继承自Employee类,主要判断标准是出现了extends关键字

共有方法:

  • Manager中调用Employee的构造方法
  • Manager中调用了Employee的getSalary()方法

Manager中特有的方法和属性:

  • bonus属性
  • public Manager(String n, double s, int year, int month, int day)的构造方法
  • getSalary()方法
  • setBonus()方法

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

  • 到底调用了Manager还是Employee的getSalary()方法要在编译运行的时候回根据e的类型来决定,这就是所谓的后期绑定。
  • staff[0]调用的是Manager类的getSalary()方法,staff[1]和staff[2]调用的是Employee类的getSalary方法,所以e先后分别调用了Manager,Employee,Employee的getSalary()方法

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

最大的好处是提高编程效率,避免了出现代码冗余,比较方便美观

3. Object类中的toString与equals

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

如果覆盖其toString()方法,其父类中的toString方法的代码还存在,覆盖但不消失
代码及运行结果:

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

代码及运行结果:

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

编写的代码:

class Fruit{
	private String name;
	public Fruit(String name) {
		super();
		this.name = name;
	}	
	 public String toString() {
	        return "Fruit [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;
	}
      
	
}
public class Main7 {
	public static void main(String[] args) {
        ArrayList<Fruit> list=new ArrayList<Fruit>();
        Scanner sc=new Scanner(System.in);        
        while(sc.hasNext()){
            String s=sc.nextLine();
            if(s.equals("end"))
                break;
            Fruit fruit=new Fruit(s);
            if(!list.contains(fruit)){
                list.add(fruit);
            }
        }
        System.out.println(list);
}
}

运行结果

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 int lastIndexOf(Object o) {
        if (o == null) {
            for (int i = size-1; i >= 0; i--)
                if (elementData[i]==null)
                    return i;
        } else {
            for (int i = size-1; i >= 0; i--)
                if (o.equals(elementData[i]))
                    return i;
        }
        return -1;
    }

由上图可以看出ArrayList的contains()方法会调用对应元素类型的equals()方法进行判断该元素是否已经在ArrayList中

4. 实验总结

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

多态编程的好处:

  • 减少编码的工作量,增强程序的可扩展性及可维护性,使代码更加简洁。
  • 一个接口,多种实现
  • 动态绑定(后期绑定),根据具体创建的对象来决定调用哪种类中的方法

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

这一题其实思路很简单,只要跟着题目的要求一步一步来就可以实现,在编写equals方法是我用了两种方法,一个是用eclipse自动生成的equals方法,一个是看了Object类的equals方法然后照葫芦画瓢写出来的,这两种方法好像都可以,但是在主函数中调用第二种方法编写的equals方法时注意要toString一下再比较,而在主函数中调用第一种方法编写的equals方法时既可直接比较也可toString一下再比较

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

  • 程序填空题:按照题目要求来就没什么问题
  • 函数题1:主要就是用super调用父类
  • 函数题2:注意next(),nextline(),nextInt()读取时的规则,判断是否为null时要用equals方法
  • 函数题3:本题主要涉及的是java中重写equals方法。先用eclipse中自动生成的equals方法,然后再根据题目要求做适当修改和调整,比如用DecimalFormat df = new DecimalFormat("#.##");来保留两位小数再比较等,不是很难

3. 码云及PTA

3.1. 码云代码提交记录


2截图PTA题集完成情况图




3统计本周完成的代码量

周次 总代码量 新增代码量 总文件数 新增文件数
2 343 343 10 10
3 498 498 8 8
5 788 788 26 26
posted on 2017-10-14 18:38  谢晗-网络1613  阅读(238)  评论(2编辑  收藏  举报