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

    1. 本周学习总结

    2. 书面作业

    Q1.clone方法##

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

    1.2 自己设计类时,一般对什么样的方法使用protected进行修饰?以作业Shape为例说明。
    protected修饰的方法或属性,除同包的类或是其子孙类以外不可被访问。
    作业Shape中,一样的是求圆和正方形的面积,周长。用protected修饰。

    1.3 在test1包中编写简单的Employee类,在test2包中新建一个TestProtected类,并在main中尝试调用test1包中的Employee的clone方法克隆一个新对象,能否成功?为什么?
    不能成功。这俩类不在一个包内,也不是继承关系。

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

    //匿名类:
    class PersonSortable2 {
    private String name;
    private int age;
    public PersonSortable2(String name, int age) {
    this.name = name;
    this.age = age;
    }
    @Override
    public String toString() {
    return this.name+"-"+this.age;
    }
    public String getName() {
    return name;
    }
    public void setName(String name) {
    this.name = name;
    }
    public int getAge() {
    return age;
    }
    public void setAge(int age) {
    this.age = age;
    }
    }
    public class comparatorAnonymous {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Comparator<PersonSortable2> NameComparator = new Comparator<PersonSortable2>(){
            public int compare(PersonSortable2 o1, PersonSortable2 o2) {
                // TODO Auto-generated method stub
                if (o1 == o2) return 0;
                return o1.getName().compareTo(o2.getName());
            }
        };
        Comparator<PersonSortable2> AgeComparator = new Comparator<PersonSortable2>(){
            public int compare(PersonSortable2 o1, PersonSortable2 o2) {
                if (o1 == o2) return 0;
                return o1.getAge()-o2.getAge();
            }
        };
        Scanner sc=new Scanner (System.in);
        int n = sc.nextInt();
        PersonSortable2[] test=new PersonSortable2[n];
        for (int i = 0; i < n; i++) {
            test[i] = new PersonSortable2(sc.next(), sc.nextInt());
        }
        System.out.println("NameComparator:sort");
        Arrays.sort(test,NameComparator);
        for (PersonSortable2 personSortable1 : test) {
            System.out.println(personSortable1);
        }
        System.out.println("AgeComparator:sort");
        Arrays.sort(test,AgeComparator);
        for (PersonSortable2 personSortable2 : test) {
            System.out.println(personSortable2);
        }
        sc.close();
    }
    

    }

    //Lambda表达式

    public class comparatorLambda {

    class PersonSortable2 {
        private String name;
        private int age;
        
        public PersonSortable2(String name, int age) {
            this.name = name;
            this.age = age;
        }
        @Override
        public String toString() {
            return this.name+"-"+this.age;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public int getAge() {
            return age;
        }
        public void setAge(int age) {
            this.age = age;
        }
    }
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner sc=new Scanner (System.in);
        int n = sc.nextInt();
        PersonSortable2[] test=new PersonSortable2[n];
        PersonSortable2 o1;
        PersonSortable2 o2;
        Comparator<PersonSortable2> NameComparator = (o1 , o2) --> o1.getName().compareTo(o2.getName());
        Comparator<PersonSortable2> AgeComparator = (o1,o2) --> o1.getAge()-o2.getAge();
        for (int i = 0; i < n; i++) {
            test[i] = new PersonSortable2(sc.next(), sc.nextInt());
        }
        System.out.println("NameComparator:sort");
        Arrays.sort(test,NameComparator);
        for (PersonSortable2 personSortable1 : test) {
            System.out.println(personSortable1);
        }
        System.out.println("AgeComparator:sort");
        Arrays.sort(test,AgeComparator);
        for (PersonSortable2 personSortable2 : test) {
            System.out.println(personSortable2);
        }
        sc.close();
    }
    

    }

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

    Comparator shapeComparator = new Comparator() {
    @Override
    public int compare(Shape o1, Shape o2) {
    //你的代码
    }
    }; ##
    shapeComparator所指的对象能够实现Comparator接口,使其对象能够使用Arrays.sort进行排序。

    Q4.GUI中的事件处理##

    4.1 写出事件处理模型中最重要的几个关键词。
    事件对象、事件源、事件监听器。

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

    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!");//事件源
    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 尝试使用图形界面改写。

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

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

  • 相关阅读:
    zoj 3591 Nim 博弈论
    zoj 3529 A Game Between Alice and Bob 博弈论
    zoj 3513 Human or Pig 博弈论
    hdu 3886 Final Kichiku “Lanlanshu” 数位DP
    2013 ACM/ICPC Asia Regional Changsha Online
    2013 ACM/ICPC Asia Regional Changsha Online G Goldbach
    hdu 4753 Fishhead’s Little Game 博弈论+记忆化搜索
    hdu 1404/zoj 2725 Digital Deletions 博弈论
    zoj 2686 Cycle Game 博弈论
    zoj 2290 Game 博弈论
  • 原文地址:https://www.cnblogs.com/hyy786030686/p/6660480.html
Copyright © 2011-2022 走看看