201521123122 《java程序设计》 第六周实验总结

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中,GetpreimeterGetAreashape的子类,因此可以用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 静态内部类的创建。

posted @ 2017-04-02 19:00  咸鱼阿明  阅读(167)  评论(0编辑  收藏  举报