zoukankan      html  css  js  c++  java
  • 201771010113 李婷华 《面向对象程序设计(java)》第七周学习总结

    一.理论知识学习部分

    1.动态绑定:又称为运行时绑定。程序在运行时会自动选择调用哪个方法。

    2.静态绑定:如果方法是private、static、final修饰的,或者是构造器,那么编译器能准确地判断应该调用哪个方法。

    3.不允许继承的类为final 类。

    4.类中的方法可定义为final的,这时子类就不能覆盖该方法。

    5.String类是final类的一个例子,不能扩展该类。

    6.如果希望超类的某些方法或域允许被子类访问,就需要在超类调用时,将这些方法或域声明为protected。

    7.java用于控制可见性的4个访问权限修饰符:private、protected、public、默认。

    8.信息隐藏的目的:(1)对类中任何实现细节的更改不会影响使用该类的代码(2)防止用户意外删除数据(3)易于使用类。

    9.不行访问修饰符时,默认为friendly。

    10.Object类java中所有类的祖先。

    11.Object类中的equals方法用于测试某个对象是否同另一个对象相等。如果需要检测两个对象状态的相等性,就需要在新类的定义中覆盖equals方法。

    12.Object类中的hashCode方法导出某个对象的散列码。散列码是任意整数,表示对象的存储地址。两个相等对象的散列码相等。

    13.ArryList类是一个采用类型参数的泛型类。为指定数组列表保存元素的对象类型,需要用一对尖括号将数组元素对象类名括起来加在后面。

    14.对象包装器:所有的基本数据类型都有着与之对应的预定义类。对象包装器是不可变的,即一旦构造了包装器,就不允许更改包装在其中的值。且对象包装器类还是final,因此不能定义他们的子类。

    15.自动打包:在Java SE 5.0中可以自动的将基本数据类型转换为包装器类的对象。

    16.枚举类是一个类,它的隐含超类是java.lang.Enum。枚举值并不是整数或其他类型,是被声明的枚举类的自身实例。枚举类不能有public修饰的构造函数。枚举值隐含都是由public、static、final修饰的。在比较两个枚举类型的值时,永远不需要调用equals方法。

    二.实验部分

    1、实验目的与要求

    1)进一步理解4个成员访问权限修饰符的用途; 

    2)掌握Object类的常用API用法;

    3)掌握ArrayList类用法与常用API;

    4)掌握枚举类使用方法;

    (5)结合本章知识,理解继承与多态性两个面向对象程序设计特征,并体会其优点;

    (6)熟练掌握Java语言中基于类、继承技术构造程序的语法知识(ch1-ch5);

    (7)利用已掌握Java语言程序设计知识,学习设计开发含有1个主类、2个以上用户自定义类的应用程序。

    2、实验内容和步骤

    实验1  补充以下程序中主类内main方法体,以验证四种权限修饰符的用法。

    public class TEST1 {

    private String t1 = "这是TEST1的私有属性";

    public String t2 = "这是TEST1的公有属性";

    protected String t3 = "这是TEST1受保护的属性";

    String t4 = "这是TEST1的默认属性";

    private void test1() {

    System.out.println("我是TEST1private修饰符修饰的方法");

    }

    public void test2() {

    System.out.println("我是TEST1public修饰符修饰的方法");

    }

    protected void test3() {

    System.out.println("我是TEST1protected修饰符修饰的方法");

    }

    void test4() {

    System.out.println("我是TEST1无修饰符修饰的方法");

    }

    }

    public class TEST2 extends TEST1{

    private String e1 = "这是TEST2的私有属性";

    public String e2 = "这是TEST2的公有属性";

    protected String e3 = "这是TEST2受保护的属性";

    String e4 = "这是TEST2的默认属性";

    public void demo1() {

    System.out.println("我是TEST2public修饰符修饰的方法");

    }

    private void demo2() {

    System.out.println("我是TEST2private修饰符修饰的方法");

    }

    protected void demo3() {

    System.out.println("我是TEST2protected修饰符修饰的方法");

    }

    void demo4() {

    System.out.println("我是TEST2无修饰符修饰的方法");

    }

    }

    public class Main {

    public static void main(String[] args) {

    TEST2 test2 = new TEST2();

    /*以下设计代码分别调用 demo1 demo2 demo3 demo4 test1 test2 test3 test4方法和t1 t2 t3 t3 e1 e2 e3 e4属性,结合程序运行结果理解继承和权限修饰符的用法与区别*/

    }

    }

    public class Main {
        public static void main(String[] args) {
            TEST2 test2 = new TEST2();
            /*在下面分别调用 demo1 demo2 demo3 demo4 test1 test2 test3 test4方法
            和t1 t2 t3 t3 e1 e2 e3 e4属性,好好理解继承和权限修饰符的用法与区别*/
            test2.demo1();
            test2.demo3();
            test2.demo4();
            test2.test2();
            test2.test3();
            test2.test4();
            String e2=test2.e2;
            String e3=test2.e3;
            String e4=test2.e4;       
            System.out.println(e2);
            System.out.println(e3);
            System.out.println(e4);
            System.out.println(test2.t2);
            System.out.println(test2.t3);
            System.out.println(test2.t4);
            
        }
    }
    public class TEST1 {
        private String t1 = "这是TEST1的私有属性";
        public String t2 = "这是TEST1的公有属性";
        protected String t3 = "这是TEST1受保护的属性";
        String t4 = "这是TEST1的默认属性";
        private void test1() {
            System.out.println("我是TEST1用private修饰符修饰的方法");
        }
        public void test2() {
            System.out.println("我是TEST1用public修饰符修饰的方法");
        }
        protected void test3() {
            System.out.println("我是TEST1用protected修饰符修饰的方法");
        }
        void test4() {
            System.out.println("我是TEST1无修饰符修饰的方法");
        }
    }
    public class TEST2 extends TEST1{
        private String e1 = "这是TEST1的私有属性";
        public String e2 = "这是TEST1的公有属性";
        protected String e3 = "这是TEST1受保护的属性";
        String e4 = "这是TEST1的默认属性";
        public void demo1() {
            System.out.println("我是TEST2用public修饰符修饰的方法");
        }
        private void demo2() {
            System.out.println("我是TEST2用private修饰符修饰的方法");
        }
        protected void demo3() {
            System.out.println("我是TEST2用protected修饰符修饰的方法");
        }
        void demo4() {
            System.out.println("我是TEST2无修饰符修饰的方法");
        }
    }

    结果:

    实验2  第五章测试程序反思,继承知识总结。

    测试程序1:

    Ÿ 编辑、编译、调试运行教材程序5-8、5-9、5-10(教材174页-177页);

    Ÿ 结合程序运行结果,理解程序代码,掌握Object类的定义及用法;

    代码:

    package equals;
    
    import java.time.*;
    import java.util.Objects;
    
    public class Employee
    {
       private String name;
       private double salary;
       private LocalDate hireDay;
    
       public Employee(String name, double salary, int year, int month, int day)
       {
          this.name = name;
          this.salary = salary;
          hireDay = LocalDate.of(year, month, day);
       }
    
       public String getName()
       {
          return name;
       }
    
       public double getSalary()
       {
          return salary;
       }
    
       public LocalDate getHireDay()
       {
          return hireDay;
       }
    
       public void raiseSalary(double byPercent)
       {
          double raise = salary * byPercent / 100;
          salary += raise;
       }
    
       public boolean equals(Object otherObject)
       {
          // 快速检查对象是否相同
          if (this == otherObject) return true;
    
          // 判断两个引用是否是同一个
          if (otherObject == null) return false;
    
          // 是同一个,则这两个对象相等
          if (getClass() != otherObject.getClass()) return false;
    
          // 另一个对象是非空雇员
          Employee other = (Employee) otherObject;
    
          // 测试是否具有相同的值
          return Objects.equals(name, other.name) && salary == other.salary && Objects.equals(hireDay, other.hireDay);
       }
    
       public int hashCode()
       {
          return Objects.hash(name, salary, hireDay); 
       }
    
       public String toString()
       {
          return getClass().getName() + "[name=" + name + ",salary=" + salary + ",hireDay=" + hireDay
                + "]";
       }
    }
    package equals;
    
    public class Manager extends Employee
    {
       private double bonus;
    
       public Manager(String name, double salary, int year, int month, int day)
       {
          super(name, salary, year, month, day);//继承父类
          bonus = 0;
       }
    
       public double getSalary()
       {
          double baseSalary = super.getSalary();//调用父类的方法
          return baseSalary + bonus;
       }
    
       public void setBonus(double bonus)
       {
          this.bonus = bonus;
       }
    
       public boolean equals(Object otherObject)
       {
          if (!super.equals(otherObject)) return false;
          Manager other = (Manager) otherObject;
          // 检查是否和其他的是同一个类
          return bonus == other.bonus;
       }
    
       public int hashCode()//继承父类的方法
       {
          return java.util.Objects.hash(super.hashCode(), bonus);
       }
    
       public String toString()
       {
          return super.toString() + "[bonus=" + bonus + "]";
       }
    }
    package equals;
    
    /**
     * This program demonstrates the equals method.
     * @version 1.12 2012-01-26
     * @author Cay Horstmann
     */
    public class EqualsTest
    {
       public static void main(String[] args)
       {
          Employee alice1 = new Employee("Alice Adams", 75000, 1987, 12, 15);
          Employee alice2 = alice1;
          Employee alice3 = new Employee("Alice Adams", 75000, 1987, 12, 15);
          Employee bob = new Employee("Bob Brandson", 50000, 1989, 10, 1);
    
          System.out.println("alice1 == alice2: " + (alice1 == alice2));
    
          System.out.println("alice1 == alice3: " + (alice1 == alice3));
    
          System.out.println("alice1.equals(alice3): " + alice1.equals(alice3));
    
          System.out.println("alice1.equals(bob): " + alice1.equals(bob));
    
          System.out.println("bob.toString(): " + bob);
    
          Manager carl = new Manager("Carl Cracker", 80000, 1987, 12, 15);
          Manager boss = new Manager("Carl Cracker", 80000, 1987, 12, 15);
          boss.setBonus(5000);
          System.out.println("boss.toString(): " + boss);
          System.out.println("carl.equals(boss): " + carl.equals(boss));
          System.out.println("alice1.hashCode(): " + alice1.hashCode());
          System.out.println("alice3.hashCode(): " + alice3.hashCode());
          System.out.println("bob.hashCode(): " + bob.hashCode());
          System.out.println("carl.hashCode(): " + carl.hashCode());
       }
    }

    结果:

    测试程序2:

    Ÿ 编辑、编译、调试运行教材程序5-11(教材182页);

    Ÿ 结合程序运行结果,理解程序代码,掌握ArrayList类的定义及用法;

    代码:

    package arrayList;
    
    import java.time.*;
    
    public class Employee
    {
       private String name;
       private double salary;
       private LocalDate hireDay;
    
       public Employee(String name, double salary, int year, int month, int day)
       {
          this.name = name;
          this.salary = salary;
          hireDay = LocalDate.of(year, month, day);
       }
    
       public String getName()
       {
          return name;
       }
    
       public double getSalary()
       {
          return salary;
       }
    
       public LocalDate getHireDay()
       {
          return hireDay;
       }
    
       public void raiseSalary(double byPercent)
       {
          double raise = salary * byPercent / 100;
          salary += raise;
       }
    }
    package arrayList;
    
    import java.util.*;
    
    /**
     * This program demonstrates the ArrayList class.
     * @version 1.11 2012-01-26
     * @author Cay Horstmann
     */
    public class ArrayListTest
    {
       public static void main(String[] args)
       {
          // 用三个雇员对象填充员工数组
          ArrayList<Employee> staff = new ArrayList<>();//泛型数组
    
          staff.add(new Employee("Carl Cracker", 75000, 1987, 12, 15));
          staff.add(new Employee("Harry Hacker", 50000, 1989, 10, 1));
          staff.add(new Employee("Tony Tester", 40000, 1990, 3, 15));
    
          // 每个人的工资涨5%
          for (Employee e : staff)
             e.raiseSalary(5);
    
          // 打印所有员工的信息
          for (Employee e : staff)
             System.out.println("name=" + e.getName() + ",salary=" + e.getSalary() + ",hireDay="
                   + e.getHireDay());
       }
    }

    测试程序3:

    Ÿ 编辑、编译、调试运行程序5-12(教材189页);

    Ÿ 结合运行结果,理解程序代码,掌握枚举类的定义及用法;

    代码:

    package enums;
    
    import java.util.*;
    
    /**
     * This program demonstrates enumerated types.
     * @version 1.0 2004-05-24
     * @author Cay Horstmann
     */
    public class EnumTest
    {  
       public static void main(String[] args)
       {  
          Scanner in = new Scanner(System.in);
          System.out.print("Enter a size: (SMALL, MEDIUM, LARGE, EXTRA_LARGE) ");
          String input = in.next().toUpperCase();
          Size size = Enum.valueOf(Size.class, input);
          System.out.println("size=" + size);
          System.out.println("abbreviation=" + size.getAbbreviation());
          if (size == Size.EXTRA_LARGE)//比较两个枚举类型的值
             System.out.println("Good job--you paid attention to the _.");      
       }
    }
    
    enum Size//声明枚举类
    {
       SMALL("S"), MEDIUM("M"), LARGE("L"), EXTRA_LARGE("XL");
    
       private Size(String abbreviation) { this.abbreviation = abbreviation; }
       public String getAbbreviation() { return abbreviation; }
    
       private String abbreviation;
    }

    实验3采用个人账号登录https://pintia.cn/完成《2018秋季西北师范大学面向对象程序设计(Java)(ch1-ch5)测试题2》,测试时间60分钟;

    实验4: 课后完成实验3未完成的测试内容。

    3.实验总结:

    在这次实验中,通过实验一我真正理解了继承,在继承时,子类不能继承父类的private属性、方法。通过后面几个测试程序,理解了ArrayList。但是在做测试题2的时候,还是有点小小的问题,第一个编程题的答案不对,想了很久也没有找到问题的关键所在。希望在以后的学习中,能尽量解决遇到的问题,以提高自己的能力。

  • 相关阅读:
    Secure your iPhone with 6 digit passcode by upgrading to iOS9
    Threatening letter in Naver Line App
    Android Malware Analysis
    OGG目录清理数据
    RAC配置2个私网网卡使用HAIP服务
    sql调优脚本
    匿名内部类
    权限修饰符
    Android源码目录结构
    luffy项目:基于vue与drf前后台分离项目(1)
  • 原文地址:https://www.cnblogs.com/litinghua/p/9782355.html
Copyright © 2011-2022 走看看