zoukankan      html  css  js  c++  java
  • 201521123062《Java程序设计》第6周学习总结

    1. 本周学习总结

    1.1 面向对象学习暂告一段落,请使用思维导图,以封装、继承、多态为核心概念画一张思维导图,对面向对象思想进行一个总结。


    2. 书面作业

    Q1.clone方法

    1.1 Object对象中的clone方法是被protected修饰,在自定义的类中覆盖clone方法时需要注意什么?

    如果要在子类中覆盖clone方法,Object对象中是被protected修饰,说明只能被同包内的类和子类访问,且父类就是Object,需要改成public修饰则。同时,针对情况,深拷贝和浅拷贝针对拷贝是引用类型情况。

    1.2 自己设计类时,一般对什么样的方法使用protected进行修饰?以作业Shape为例说明。

    protected的访问权限是本类,同包和子类,当子类想要访问父类的属性和方法时,可以使用protected,但是不可以被外部包访问。Shape中的getPerimeter与getArea分别为计算面积与周长的方法,很明显只有继承了Shape的子类才具有这两种方法,因此可用protected修饰。

    1.3 在test1包中编写简单的Employee类,在test2包中新建一个TestProtected类,并在main中尝试调用test1包中的Employee的clone方法克隆一个新对象,能否成功?为什么?

    不能成功,编译失败
    他们不在同一个包内,也不是继承关系,需要插入import test1.Employee。


    Q2.使用匿名类与Lambda表达式改写题集面向对象2-进阶-多态接口内部类的题目5-2,仅需粘贴关键代码与运行结果,图片不要太大。

    class NameComparator implements Comparator<PersonSortable2>
    {
        @Override
        public int compare(PersonSortable2 p1,PersonSortable2 p2)
        {
            if(!p1.getName().equals(p2.getName())){
            	if(p1.getName().compareTo(p2.getName())>0)
            		return 1;
            	else
            		return -1;
            }
            return 0;
        }
    }
    

    运行结果如下:




    Q3.分析下列代码,回答shapeComparator所指向的对象与Comparator接口有什么关系?

    Comparator<Shape> shapeComparator = new  Comparator<Shape>() {  
         @Override  
         public int compare(Shape o1, Shape o2) {  
             //你的代码     
          }         
    };
    

    shapeComparator所指向的对象只是为了实现Comparator接口,对继承方法的调用或覆盖,并且可以通过Collection.sort进行调用。


    Q4.GUI中的事件处理

    4.1 写出事件处理模型中最重要的几个关键词。

    事件监听器、事件对象、事件源。

    4.2 使用代码与注释,证明你理解了事件处理模型。

    视频中的例子

    private void calActionPerformed(java.awt.event.ActionEvent evt) {
                                        
            String a=aTextField.getText();//输入字符串a
    
            String b=bTextField.getText();//输入字符串b
    
            result.setText(a+b);//合并字符串
        }    
    

    3. 码云上代码提交记录及PTA实验总结

    3.1. 码云代码提交记录

    在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

    3.2. PTA实验

    5.3 ArrayIntegerStack,是用来判断是否栈空或栈满,内部建立一个数组和一个标记top,记录栈顶位置。
    5.4 对于使用匿名类的问题,匿名类与Lambda表达式简化代码,可以直接写在排序语句内。在匿名内部类中存取局部变量,该变量必须是final。


  • 相关阅读:
    hdu_5791_Two(DP)
    hdu_5783_Divide the Sequence(贪心)
    hdu_5769_Substring(后缀数组)
    hdu_5778_abs(暴力)
    hdu_5776_sum(前缀和维护)
    hdu_5777_domino(贪心)
    [wikioi2069]油画(贪心)
    [bzoj 1503][NOI 2004]郁闷的出纳员(平衡树)
    数据结构练习
    [poj3274]排排站(Hash)
  • 原文地址:https://www.cnblogs.com/GOB8023/p/6658839.html
Copyright © 2011-2022 走看看