• 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 静态内部类的创建。

  • 相关阅读:
    zbb20170802 Windows平台使用Gitblit搭建Git服务器图文教程
    zbb20170728 oracle 查看被锁对象
    zbb20170726 Spring Controller 获取请求参数的几种方法
    zbb20170726 spring访问静态文件访问
    zbb20170720 extjs 类似桌面的页面布局
    zbb20170718 Eclipse 导入外部项目无法识别为web项目并且无法在部署到tomcat下
    zbb20170717Spring4 MVC Hibernate4集成 Annotation maven 各种版本
    zbb20170630 web项目发布至tomcat的ROOT下方法(开发环境和部署环境)
    3.语句的增删改查
    1、java面试
  • 原文地址:https://www.cnblogs.com/fenm/p/6659581.html
Copyright © 2020-2023  润新知