• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Tonya
博客园    首页    新随笔    联系   管理    订阅  订阅
201521123007《Java程序设计》第6周学习总结

1. 本周学习总结

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


2. 书面作业

1. clone方法

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

首先我们来了解一下Object类中的clone()方法:

  • 可以知道clone方法被protected修饰,因此只能在同包或子类中访问,这样局限性就很大,因此覆盖clone方法是要声明public;
  • 在自定义类中覆盖clone方法时必须要实现Cloneable接口,否则就会出错;
  • 返回的对象通过调用super.clone()获得,同时引用字段要使用对副本的引用替换对这些对象的引用,也就是要使用.clone(),基本字段或对不变对象的引用就不需要修改字段

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

当某些方法只想被子类和同包访问的时候用protected修饰,以shape为例其中getPerimeter与getArea方法只有继承的子类才有这种方法所以用protected修饰。

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

随便举个例子:

package test1;

public class Employee implements Cloneable {
	private String name;
	private double price;
	
	public Employee(String name, double price) {
		super();
		this.name = name;
		this.price = price;
	}

	@Override
	public String toString() {
		return "Employee [name=" + name + ", price=" + price + "]";
	}

	@Override
	protected Employee clone() throws CloneNotSupportedException {
		Employee e=(Employee) super.clone();
		return e;
	}
}
package test2;

import test1.Employee;

public class TestProtected {
	public static void main(String[] args) throws CloneNotSupportedException {
		Employee e=new Employee("li",2.6);
		System.out.println(e.clone());
	}
}

可以看到会出错,提示Employee类的clone()方法对TestProtected类是不可见的,如果把protected修饰改成public或者把两个类文件放在一个包里面就可以编译成功。

2. 使用匿名类与Lambda表达式改写题集面向对象2-进阶-多态接口内部类的题目5-2

使用匿名类改写部分代码如下:

			Collections.sort(persons,new Comparator<PersonSortable2>(){

				@Override
				public int compare(PersonSortable2 o1, PersonSortable2 o2) {
					return o1.getName().compareTo(o2.getName());
				}
				
			});
			System.out.println("NameComparator:sort");
			for (PersonSortable2 p : persons) {
				System.out.println(p);
			}
			Collections.sort(persons,new Comparator<PersonSortable2>(){

				@Override
				public int compare(PersonSortable2 o1, PersonSortable2 o2) {
					return o1.getAge()-o2.getAge();
				}
				
			});
			System.out.println("AgeComparator:sort");
			for (PersonSortable2 p : persons) {
				System.out.println(p);
			}

运行结果

使用Lambda表达式改写部分代码如下:

			Comparator<PersonSortable2> nameComparator = (o1,o2)->o1.getName().compareToIgnoreCase(o2.getName());
			Collections.sort(persons,nameComparator);
			System.out.println("NameComparator:sort");
			for (PersonSortable2 p : persons) {
				System.out.println(p);
			}
			Comparator<PersonSortable2> ageComparator = (o1,o2)->o1.getAge()-o2.getAge();
			Collections.sort(persons,ageComparator);
			System.out.println("AgeComparator:sort");
			for (PersonSortable2 p : persons) {
				System.out.println(p);
			}

运行结果如下:

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

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

shapeComparator这个对象操作了Comparator这个接口,使用匿名内部类实现Comparator接口并重写其中的抽象方法compare。以下是引用别人的话,写得不错的:

匿名内部类既可以扩展类,也可以实现接口,但是不能像正规的继承那样两者兼备,而且如果是实现接口,也只能实现一个接口。在Java8之前要求匿名内部类使用的外部定义的对
象必须得是final类型的,但是在Java8之后就取消了这个限制。

4. GUI中的事件处理

任何支持GUI的环境操作都要不断地监视敲击键盘或点击鼠标这样的事件,操作环境将这些事件报告给正在运行的应用程序。

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

  • 事件:描述发生了什么的对象,如敲击键盘、点击鼠标等各种不同类型的事件类用来描述各种类型的用户交互。
  • 事件源:一个事件的产生者,用户在各种场合进行的各项操作,如用鼠标点击某个组件等。
  • 事件监听器:实现了监听器接口的类,各种类型的事件均有对应的时间处理器接口,该接口封装了与其对应类型事件的各种处理方法,并建立了事件到相应处理方法的自动映射。

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

import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;

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!");//鼠标点击"Press Me!"就是一个事件,b表示这个事件产生了
		b.addActionListener(new ButtonHandler());//注册监听器
		f.add(b);//添加按钮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());//获得事件源
		}

	}
}

5. 结对编程:面向对象设计(大作业2-非常重要,未完成-2)

继续完善上周的项目作业。考核点如下:

5.1 尝试使用图形界面改写。

5.2 给出两人在码云上同一项目的提交记录截图。

5.3 与上周相比,项目的主要改动是什么?

只做出了界面,里面具体操作还不能执行。


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

题目集:jmu-Java-04-面向对象2-进阶-多态接口内部类

3.1. 码云代码提交记录

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

3.2. PTA实验

函数(选做:4-1)、编程(5-3, 5-4)

一定要有实验总结

  • 接口是方法的声明和常量值的定义的集合,只能声明方法而没有具体行为;
  • 常量值和方法必须是public修饰;
  • 实现了接口的类可以用接口来声明对象类型,如IntegerStack stack=new ArrayIntegerStack(n);;
  • 生成(new)一个静态内部类不需要外部类成员;
posted on 2017-04-02 18:41  七秒の鱼  阅读(273)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3