201521123122 《java程序设计》第六周实验总结
1. 本周学习总结
1.1 面向对象学习暂告一段落,请使用思维导图,以封装、继承、多态为核心概念画一张思维导图,对面向对象思想进行一个总结。
注1:关键词与内容不求多,但概念之间的联系要清晰,内容覆盖面向对象的核心内容即可。
注2:颜色要少、连线不要复杂,必要的时候要在连线上进行说明。
2. 书面作业
clone方法
1.1 Object对象中的clone
方法是被protected
修饰,在自定义的类中覆盖clone方法时需要注意什么?
1.一般来说,用protected修饰的方法,子类和父类要在同一个包中才可以使用。
2.克隆对象的两个步骤,覆盖clone方法,声明为public,实现cloneable接口。在自定义类中覆盖clone,要重写clone方法,并把它声明为public。
3.还有关于浅拷贝和深拷贝的问题,浅拷贝简单来说,制就是指创建一块区域存储复制体对象,但实际上复制体与本体引用的是同一块内存区域。所以要使用深拷贝,即克隆包含在对象中的其他引用型属性。
1.2 自己设计类时,一般对什么样的方法使用protected
进行修饰?以作业Shape
为例说明。
如果有些方法只想让同类的包或子类访问时,可以采用
protected
方法,在shape
中,Getpreimeter
和GetArea
是shape
的子类,因此可以用protected修饰。
1.3 在test1包中编写简单的Employee类,在test2包中新建一个TestProtected类,并在main中尝试调用test1包中的Employee的clone方法克隆一个新对象,能否成功?为什么?
不能成功,上面说了 object类中的克隆方法是用protected修饰的,然后这两个类不在同一个包中,也没有什么继承关系。所以要写clone方法时,一般用public来修饰。 下面贴代码:
package text1;
public class Employee implements Cloneable{
private String name;
private double salary;
public Employee(String name, double salary) {
super();
this.name = name;
this.salary = salary;
}
@Override
protected Employee clone() throws CloneNotSupportedException {
// TODO Auto-generated method stub
return null;
}
}
package text2;
import text1.*;
public class TestProtected<Employee> {
Employee employee = new Employee("ss", 100.0);
Employee employee2 = employee.clone();
}
错误如图:
使用匿名类与Lambda表达式改写题集面向对象2-进阶-多态接口内部类的题目5-2
匿名类关键代码
Comparator<PersonSortable2> NameComparator = new Comparator<PersonSortable2>() {
public int compare(PersonSortable2 o1,PersonSortable2 o2) {
if (o1.getName().compareTo(o2.getName()) > 0) return 1;
if (o1.getName().compareTo(o2.getName()) < 0) return -1;
return 0;
}
};
Comparator<PersonSortable2> AgeComparator = new Comparator<PersonSortable2>() {
public int compare(PersonSortable2 o1,PersonSortable2 o2) {
if (o1.getAge() > o2.getAge()) return 1;
if (o1.getAge() < o2.getAge()) return -1;
return 0;
}
};
Lambda表达式关键代码:
Comparator<PersonSortable2> NameComparator=(o1,o2)-> o1.getName().compareTo(o2.getName());
Comparator<PersonSortable2> AgeComparator=(o1,o2)-> o1.getAge()-o2.getAge();
结果如图:
分析下列代码,回答shapeComparator所指向的对象与Comparator接口有什么关系?
Comparator<Shape> shapeComparator = new Comparator<Shape>() {
@Override
public int compare(Shape o1, Shape o2) {
//你的代码
}
};
shapeComparator所指向的对象是一个Shape类实现的Comparable接口,实现Comparable接口之后可以进行比较。
GUI中的事件处理
4.1 写出事件处理模型中最重要的几个关键词
1.事件:用户在GUI组件上进行的操作,如鼠标单击、输入文字、关闭窗口等;
2.事件源:能够产生事件的GUI组件对象,如按钮、文本框等;
3.事件监听器:调用事件处理方法的对象;
4.事件适配器:在适配器中,实现了相应监听器接口的所有方法,但不做任何处理。
4.2 使用代码与注释,证明你理解了事件处理模型。
public class EventMainGUI1 extends Frame {
static int count = 1;
public EventMainGUI1(String title) {
super(title);
}
public static void main(String args[]) {
//初始化窗口
EventMainGUI1 f = new EventMainGUI1("hello");
f.setLayout(new FlowLayout());
//定义一个按钮b(事件源),并赋上初始值1。
final JButton b = new JButton("1");
//注册监听器,按钮上的值每当b按钮被按下即+1。
b.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent evt) {
b.setLabel(new Integer(++count).toString());
}
});
f.add(b);//把b按钮加入f窗口
f.setSize(100, 100);
f.setBackground(Color.blue);//设置背景色
f.setVisible(true);//该窗口可见
}
}
3. 码云上代码提交记录及PTA实验总结
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
3.2. PTA实验
这次在老师的指导下,终于把这两个实验写完了。一开始会看不懂,真正理解了还是比较简单的。
5-3 主要是使用数组完成栈的情况,最主要的是判断栈空和栈满的情况。
5-4 静态内部类的创建。