201521123014 《Java程序设计》第6周学习总结

1. 本周学习总结#

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

201521123014 《Java程序设计》第6周学习总结

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

  • GUI与Swing
  • 使用NetBeans设计GUI
  • 顶层窗口被称为框架(Frame) AWT中叫Frame Swing中叫JFrame
  • 了解并使用布局管理器 如FlowLayout BorderLayout
  • ActionListener-最常用的事件处理器(事件---------事件监听器)

2. 书面作业#

Q1 clone方法##

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

答:clone方法中被protected修饰,那就表明子类要运用clone方法必须与父类在同一个包中。因此我们在自定义的类中要覆盖clone方法并声明为public。还要让类操作Cloneable接口。

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

protected的访问权限是本类,同包和子类,当子类想要访问父类的属性和方法时,可以使用protected。例如:子类圆形和正方形想调用父类Shape中的getArea()方法,就可以写成protected double getArea().
abstract class Shape {
private final static double PI = 3.14;
public abstract double getArea();
}

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

package test1;

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 Object clone() throws CloneNotSupportedException {
// TODO Auto-generated method stub
return super.clone();
} }

201521123014 《Java程序设计》第6周学习总结


答:编译失败,原因是The method clone() from the type Employee is not visible 所以写clone()方法,一般都用public来修饰。

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

Comparator<PersonSortable2> nameComparator =
new Comparator<PersonSortable2>(){ @Override
public int compare(PersonSortable2 o1, PersonSortable2 o2) {
// TODO Auto-generated method stub
return o1.getName().compareTo(o2.getName());
} };
//匿名内部类对姓名的排序 Comparator<PersonSortable2> ageComparator =
new Comparator<PersonSortable2>(){ @Override
public int compare(PersonSortable2 o1, PersonSortable2 o2) {
// TODO Auto-generated method stub
if (o1.getAge() < o2.getAge()) {
return -1;
} else if (o1.getAge() > o2.getAge()) {
return 1;
} else {
return 0;
}
} };//匿名内部类对age的排序

运行结果:201521123014 《Java程序设计》第6周学习总结

Arrays.sort(person,(o1,o2)->o1.getName().compareTo(o2.getName()));
```//Lambda表达式对Name排序

Arrays.sort(person,(o1,o2)->o1.getAge()-o2.getAge());



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

Comparator shapeComparator = new Comparator() {

@Override

public int compare(Shape o1, Shape o2) {

//你的代码

}

};


答:shapeComparator这个对象操作了Comparator这个接口。要创建匿名内部类也要和定义类的时候操作接口一样,重写接口当中的抽象方法。


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

任何支持GUI的操作环境都要不断地监视

敲击键盘或点击鼠标这样的事件

事件源:能够产生时间的一些组件,如botton。

监听器:当某个事件发生的时候,希望执行一段与该事件对应的代码。这段被执行的代码应放到相应监听器中的某个方法中。


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

//定义专门的外部类实现监听接口

public class MainGUI {

public static void main(String[] args) {

JFrame f = new JFrame("Test");

f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

JButton b = new JButton("Press Me!");//事件源

b.addActionListener(new ButtonHandler());//注册监听器

f.add(b);

f.setSize(200, 100);

f.setVisible(true);

}

private static class ButtonHandler implements

ActionListener{//监听器

public void actionPerformed(ActionEvent e) {

System.out.println("Action occurred");

System.out.println(e.getSource());//获得事件源

}

}

}


##Q5 结对编程:面向对象设计##
继续完善上周的项目作业。考核点如下:
###5.1 尝试使用图形界面改写。###
(只是做了大概,因为有一些操作方法还是不懂,无法实现其他功能!!!)
登录界面:
![](http://images2015.cnblogs.com/blog/1109839/201704/1109839-20170402165642883-454650957.png)
商品界面: ![](http://images2015.cnblogs.com/blog/1109839/201704/1109839-20170402165650149-1949740989.png)
购物车界面: ![](http://images2015.cnblogs.com/blog/1109839/201704/1109839-20170402165656649-1751781745.png)

private void accountActionPerformed(java.awt.event.ActionEvent evt) {

String a=account.getText();

// TODO add your handling code here:

}


###5.2 给出两人在码云上同一项目的提交记录截图。###
自己做的。
###5.3 与上周相比,项目的主要改动是什么?###
大部分方法要结合Netbeans里的组件来完成。
#3 码云上代码提交记录及PTA实验总结#
![](http://images2015.cnblogs.com/blog/1109839/201704/1109839-20170402165636461-1517606594.png) #4 PTA实验#
5.3 ArrayIntegerStack,功能与栈一样,在内部建立一个数组和一个标记top,记录栈顶位置,判断是否栈空或栈满,private Integer[] arr; private int top=0;,实现接口的功能,主要是top的值的改变,最难的是判断栈空和栈满时,要输出对应数量的null,此时可根据top-arr.length的差值来输出null的个数。如果用ArrayList操作的话,就是用add()和remove()方法来实现,相对来说会简单一些。
5.4 静态内部类,主要在外部类的方法中,创建内部类对象,使用内部类的属性,静态内部类不能直接访问外部类的非静态成员,但可以通过 new 外部类().属性 的方式访问。
上一篇:TeXLive安装过程


下一篇:对OAuth2.0协议的理解和测试demo