201871020225-牟星源《面向对象程序设计(java)》第6-7周学习总结

博文正文:

项目

内容

这个作业属于哪个课程

https://www.cnblogs.com/nwnu-daizh/

这个作业的要求在哪里

https://www.cnblogs.com/nwnu-daizh/p/11605051.html

作业学习目标

  1. 深入理解程序设计中算法与程序的关系;
  2. 深入理解java程序设计中类与对象的关系;
  3. 理解OO程序设计的第2个特征:继承、多态;
  4. 学会采用继承定义类设计程序(重点、难点);
  5. 能够分析与设计至少包含3个自定义类的程序;
  6. 掌握利用父类定义子类的语法规则及对象使用要求。

随笔博文正文:

第一部分:总结第五章理论知识(30分)

1.  继承:用已有类来构建新类。子类不仅继承了父类的方法和域,还在子类中添加新的方法和域。

特点:具有层次结构;子类继承了父类的方法和域。

类继承格式:class 子类名  extends 父类名

父类(来自系统类库;用户自定义类)

需要注意的是:(1)在子类中可以增加域、方法或覆盖父类的方法,但不能删除父类的任何域和方法。

(2)一个子类可以有一个父类,但一个父类可以有多个子类,即Java不支持多继承。

2.多态性:泛指在程序中同一个符号在不同的情况下具有不同解释的现象。

(1)Java中,对象变量是多态的。

(2)继承层次结构中,每个子类对象也可看成父类对象,因此可以将子类对象赋给超类变量。

(3)不能把对超类的对象引用赋给子类对象变量。

3.抽象类:(abstract class Person)包含一个或多个抽象方法的类本身必须被声明为抽象类。

(1)除了抽象方法之外,抽象类还可以包含具体数据和具体方法。

(2)抽象方法具体实现在子类中。

(3)abstract方法不能被实例化,即只能声明,不能实现。

应当注意的是(1)扩展抽象类:一种是在子类中实现部分抽象方法,而子类也被标记为抽象类;

(2)另一种是实现全部抽象方法,这样子类就可以不是抽象类。此外,类即使不含抽象方法,也可以将类声明为抽象类。

4.阻止继承:final类和方法

(1)final类:不允许继承的类,在类的定义中用final修饰符加以说明。

(2)如果一个类声明为final,属于它的方法会被自动设为final. 但不包括域(如果域定义为final,在对象构造以后,final城就不能再修改了)

5.强制类型转换

(1)如果要把一个超类对象赋给一个子类对象变量,就必须进行强制类型转换,格式如下:子类  对象 = (子类) (父类对象)

Eg:Manager boss=(Manager)staff【0】;

(2)类型转换必须在继承层次内进行,且在父类转换为子类之前。应先使用instanceof操作符进行继承链检查(应该尽量少用类型转换和instanceof运算符)继承用extends关键字来实现.除构造方法之外。父奖的所有方法和属性都被子奖继承.,继承建立了类与类间的关系。同时也是多态特征的前提。

6.受保护访问:如果希望父类的某些方法或域允许被子类直接访问,就需要在父类定义时,将这些方法或域声明为producted。

7.object:所有类的超类 :

  (1)在java中,只有基本类型不是对象,其他类型(包括数组,枚举)都是对象,都扩展于超类
  (2)Object类是Java中所有类的开始——每一个类都由它扩 展而来。在不给出超类的情况下,Java会自动把Object 作为要定义类的超类。 
   (3)可以使用类型为Object的变量指向任意类型的对象。但 要对它们进行专门的操作都要进行类型转换。
 (4)equals方法:定义子类的equals方法时,可调用超类的equals方法。 super.equals(otherObject)
  (5)hashCode方法:Object类中的hashCode方法导出某个对象的散列 码。散列码是任意整数,表示对象的存储地址。 注:两个相等对象的散列码相等。

8.泛型数组列表:

  (1)利用ArrayList类,课允许程序在运行时确定数组的大小。

注:ArrayList是一个采用类型参数的泛类型。

9.对象包装器与自动装箱:
  (1)每个基本类型都有之对应的类(对象包装类)
  (2)对象包装类不允许修改其中的值,同时也是final声明的
  (3)使用包装器声明变量时,其==表示其是否指向同一个对象,因此
  (4)两个对象包装器比较时调用equal方法
10.参数数量可变的方法
  (1)java 使用持有者类型(IntHolder、BooleanHold等)
  (2)可变参数 使用:public static double max(double... value);实际上将若干参数绑定在数组中传递该max函数:public static void main(String... args)。
11.枚举类:
  (1)实际上是一个类,包含若干个实例,因此两个枚举类型的值比较,直接使用 == ,永远不要调用equal。 
  (2)所有的枚举类型都是Enum类的子类。所以他们继承了这个类的许多方法String toString() //返回枚举常量名
  (3)static Enum valueOf(Class enumClass,String name)//返回指定名字给定类的枚举常量
  (4)int ordinal() //返回在enum声明中枚举常量的索引 (从0 开始)
  (5)int compareTo(E other) //在枚举中的顺序比较
12.反射:
  (1)反射被大量用在javaBeans中。
  (2)反射的作用:
     ①在运行中分析类的能力
     ②在运行在查看类的对象
     ③实现通过的数组操作代码
     ④利用Method对象。

第二部分:实验部分

1、实验目的与要求

(1) 理解继承的定义;

(2) 掌握子类的定义要求

(3) 掌握多态性的概念及用法;

(4) 掌握抽象类的定义及用途。

2、实验内容和步骤

实验1:测试程序1

在elipse IDE中编辑、调试、运行程序5-1 —5-3(教材152页-153页) ;

掌握子类的定义及用法;

结合程序运行结果,理解并总结OO风格程序构造特点,理解Employee和Manager类的关系子类的用途,并在代码中添加注释;

删除程序中Manager类、ManagerTest类,背录删除类的程序代码,在代码录入中理解父类与子类的关系和使用特点。

5.1代码

package inheritance;
 
/**
 * This program demonstrates inheritance.
 * @version 1.21 2004-02-21
 * @author Cay Horstmann
 */
public class ManagerTest
{
   public static void main(String[] args)
   {
      // construct a Manager object   构造一个manager对象
      var boss = new Manager("Carl Cracker", 80000, 1987, 12, 15);  //将经理放到数组中去
      boss.setBonus(5000);   //由boss.setBonus单独设置津贴,其中setBonus是Manager的特有方法
 
      var staff = new Employee[3];     //定义一个包含三个雇员的数组
 
      // fill the staff array with Manager and Employee objects
 
      staff[0] = boss;        // 父类可以引用子类
      staff[1] = new Employee("Harry Hacker", 50000, 1989, 10, 1);   //将经理和雇员都放到数组中去
      staff[2] = new Employee("Tommy Tester", 40000, 1990, 3, 15);
 
      // print out information about all Employee objects
      for (Employee e : staff)     //for循环打印出各个雇员对象的信息
         System.out.println("name=" + e.getName() + ",salary=" + e.getSalary());
   }
}

结果

5.2代码

package inheritance;
 
import java.time.*;
 
public class Employee
{
   private String name;//private定义了一个只能在该类中访问的字符串常量
   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;
   }
}结果

5.3代码

package inheritance;
 
public class Manager extends Employee    //由继承Employee类来定义Manager类的格式,关键字extend表示继承
{
   private double bonus;
 
   /**
    * @param name the employee's name
    * @param salary the salary
    * @param year the hire year
    * @param month the hire month
    * @param day the hire day
    */
   public Manager(String name, double salary, int year, int month, int day)
   {
      super(name, salary, year, month, day);    //调用超类Employee中含有这些参数的构造器
      bonus = 0;
   }
 
   public double getSalary()
   {
      double baseSalary = super.getSalary();    //用关键字super调用超类Employee中的getsalary方法
      return baseSalary + bonus;
   }
 
   public void setBonus(double b)
   {
      bonus = b;
   }
}

结果

实验1:测试程序2

编辑、编译、调试运行教材PersonTest程序(教材163页-165页);

掌握超类的定义及其使用要求;

掌握利用超类扩展子类的要求;

在程序中相关代码处添加新知识的注释;

删除程序中Person类、PersonTest类,背录删除类的程序代码,在代码录入中理解抽象类与子类的关系和使用特点。

5.4代码

package abstractClasses;
 
/**
 * This program demonstrates abstract classes.
 * @version 1.01 2004-02-21
 * @author Cay Horstmann
 */
public class PersonTest
{
   public static void main(String[] args)
   {
      var people = new Person[2];   //定义一个包含2个雇员的数组
 
      // fill the people array with Student and Employee objects
      people[0] = new Employee("Harry Hacker", 50000, 1989, 10, 1);
      people[1] = new Student("Maria Morris", "computer science");   //将雇员和学生的对象填充到Person引用数组
 
      // print out names and descriptions of all Person objects
      for (Person p : people)
         System.out.println(p.getName() + ", " + p.getDescription());   // 输出对象的姓名和信息描述
   }
}

结果

5.5代码

package abstractClasses;
 
public abstract class Person   // 使用abstract关键字
{
   public abstract String getDescription();   // 定义抽象类型person
   private String name;
 
   public Person(String name)
   {
      this.name = name;//将局部变量的值赋给成员变量
   }//为子类person类的构造器提供代码的构造器
   public String getName()
   {
      return name;    //Person类中还保存着姓名和一个返回姓名的方法
   }//构造器
}

结果

5.6代码

package abstractClasses;
 
import java.time.*;
 
public class Employee extends Person  //扩展了一个子类Person
{
   private double salary;
   private LocalDate hireDay;
 
   public Employee(String name, double salary, int year, int month, int day)//定义变量
   {
      super(name);
      this.salary = salary;
      hireDay = LocalDate.of(year, month, day);//hireday使用LocalDate的方法
   }
 
   public double getSalary()
   {
      return salary;
   }
 
   public LocalDate getHireDay()
   {
      return hireDay;
   }
 
   public String getDescription()
   {
      return String.format("an employee with a salary of $%.2f", salary);
   }
 
   public void raiseSalary(double byPercent)
   {
      double raise = salary * byPercent / 100;
      salary += raise;
   }
}

结果

5.7代码

package abstractClasses;
 
public class Student extends Person  //扩展了一个子类Student
{
   private String major;
 
   /**
    * @param name the student's name
    * @param major the student's major
    */
   public Student(String name, String major)
   {
      // pass name to superclass constructor
      super(name);
      this.major = major;   //将名称传递给超类构造函数
   }
 
   public String getDescription()
   {
      return "a student majoring in " + major;  //返回学生信息
   }
}

结果

实验1:测试程序3

编辑、编译、调试运行教材程序5-8、5-9、5-10,结合程序运行结果理解程序(教材174页-177页);

掌握Object类的定义及用法;

在程序中相关代码处添加新知识的注释。

5.8代码

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)
   {
      var alice1 = new Employee("Alice Adams", 75000, 1987, 12, 15);
      var alice2 = alice1;
      var alice3 = new Employee("Alice Adams", 75000, 1987, 12, 15);
      var 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);
 
      var carl = new Manager("Carl Cracker", 80000, 1987, 12, 15);
      var 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());
   }
}

结果

5.9代码

package equals;
 
import java.time.*;
import java.util.Objects;
 
public class Employee
{
   private String name;//private定义了一个只能在该类中访问的字符串变量
   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)
   {
      // a quick test to see if the objects are identical  快速测试这些对象是否相同
      if (this == otherObject) return true;
 
      // must return false if the explicit parameter is null   如果显示参数为空,必须返回false
      if (otherObject == null) return false;
 
      // if the classes don't match, they can't be equal   如果第几个类不匹配,则他们不相同
      if (getClass() != otherObject.getClass()) return false;
 
      // now we know otherObject is a non-null Employee   //其他对象为非空Employee类
      var other = (Employee) otherObject;
 
      // test whether the fields have identical values   //测试是不是有相同值
      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 + "]";
   }
}

结果

5.10代码

package equals;
 
public class Manager extends Employee  //扩展了一个子类Manager
{
   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;
      var other = (Manager) otherObject;
      // super.equals checked that this and other belong to the same class  用super.equals检查这个类和其他类是否属于同一个类
      return bonus == other.bonus;
   }
 
   public int hashCode()
   {
      return java.util.Objects.hash(super.hashCode(), bonus);
   }
 
   public String toString()//吧其他类型的数据转换为字符串类型的数据
   {
      return super.toString() + "[bonus=" + bonus + "]";
   }
}

结果

实验2:编程练习

代码

import java.util.Scanner;
 
abstract class Shape {
    double PI = 3.14;
 
    public abstract double getPerimeter();
 
    public abstract double getArea();
}
 
class Rectangle extends Shape {
    int wide, len;
 
    Rectangle(int a, int b) {
        wide = a;
        len = b;
    }
 
    @Override
    public double getPerimeter() {
        // TODO Auto-generated method stub
        return 2 * (wide + len);
    }
 
    @Override
    public double getArea() {
        // TODO Auto-generated method stub
        return wide * len;
    }
    
    public String toString(){
        return "[width=" + wide + ", length=" + len + "]";
    }
}
 
class Circle extends Shape {
    int radius;
 
    Circle(int _radius) {
        radius = _radius;
    }
 
    @Override
    public double getPerimeter() {
        // TODO Auto-generated method stub
        return radius * 2 * PI;
    }
 
    @Override
    public double getArea() {
        // TODO Auto-generated method stub
        return radius * radius * PI;
    }
 
    public String toString(){
        return "[radius=" + radius + "]";
    }
 
}
 
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        in.nextLine();
        Shape A[] = new Shape[n];
        int k = 0, j = 0;
        double sumAllArea = 0, sumAllPerimeter = 0;
        for (int i = 0; i < n; i++) {
            String S = in.next();
            if (S.equals("rect")) {
                int wide = in.nextInt(), len = in.nextInt();
                in.nextLine();
                A[i] = new Rectangle(wide, len);
            } else if (S.equals("cir")) {
                int radius = in.nextInt();
                in.nextLine();
                A[i] = new Circle(radius);
            }
            sumAllArea += A[i].getArea();
            sumAllPerimeter += A[i].getPerimeter();
        }
 
        System.out.println(sumAllPerimeter);
        System.out.println(sumAllArea);
        System.out.print("[");
        for (int i = 0; i < n; i++) {
            if(i != 0)
                System.out.print(", ");
            if (A[i] instanceof Rectangle) {
                    System.out.print("Rectangle ");
                System.out.print(A[i].toString());
            }
            else {
                    System.out.print("Circle ");
                System.out.print(A[i].toString()); 
            }
        }
 
        System.out.println("]");
 
        for(int i = 0;i < n;i++) {
            if(A[i] instanceof Rectangle) {
                System.out.println("class Rectangle,class Shape");
            }else {
                System.out.println("class Circle,class Shape");
 
            }
        }
        in.close();
    }
}

结果

2.  实验总结:

通过这两周的学习,基本掌握了Java中继承的用法和作用,理解继承的定义,通过这次实验,我学习到了子类的定义要求,掌握多态性的概念及用法,掌握抽象类的定义方法及用途,知道了枚举类定义方法及用途。通过继承内容在编程中的应用,代码的逻辑结构更清晰,对我们的算法设计思维也有所帮助,同时,在自己自主学习过程中依然有碰到困难,在日后的学习中平时会加强自主学习,努力解决在学习中遇到的问题,提高编程能力。

201871020225-牟星源《面向对象程序设计(java)》第6-7周学习总结的更多相关文章

  1. 201571030332 扎西平措 《面向对象程序设计Java》第八周学习总结

    <面向对象程序设计Java>第八周学习总结   项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https: ...

  2. 201771010118马昕璐《面向对象程序设计java》第八周学习总结

    第一部分:理论知识学习部分 1.接口 在Java程序设计语言中,接口不是类,而是对类的一组需求描述,由常量和一组抽象方法组成.Java为了克服单继承的缺点,Java使用了接口,一个类可以实现一个或多个 ...

  3. 201771010134杨其菊《面向对象程序设计java》第十周学习总结

    第8章泛型程序设计学习总结 第一部分:理论知识 主要内容:   什么是泛型程序设计                   泛型类的声明及实例化的方法               泛型方法的定义      ...

  4. 201771010134杨其菊《面向对象程序设计java》第八周学习总结

    第八周学习总结 第一部分:理论知识 一.接口.lambda和内部类:  Comparator与comparable接口: 1.comparable接口的方法是compareTo,只有一个参数:comp ...

  5. 201771010134杨其菊《面向对象程序设计java》第七周学习总结

    第七周学习总结 第一部分:理论知识 1.继承是面向对象程序设计(Object Oriented Programming-OOP)中软件重用的关键技术.继承机制使用已经定义的类作为基础建立新的类定义,新 ...

  6. 201871010126 王亚涛《面向对象程序设计 JAVA》 第十三周学习总结

      内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p/ ...

  7. 201771010118 马昕璐《面向对象程序设计java》第十周学习总结

    第一部分:理论知识学习部分 泛型:也称参数化类型(parameterized type)就是在定义类.接口和方法时,通过类型参数 指示将要处理的对象类型. 泛型程序设计(Generic program ...

  8. 马凯军201771010116《面向对象程序设计Java》第八周学习总结

    一,理论知识学习部分 6.1.1 接口概念 两种含义:一,Java接口,Java语言中存在的结构,有特定的语法和结构:二,一个类所具有的方法的特征集合,是一种逻辑上的抽象.前者叫做“Java接口”,后 ...

  9. 周强201771010141《面向对象程序设计Java》第八周学习总结

    一.理论知识学习部分 Java为了克服单继承的缺点,Java使用了接口,一个类可以实现一个或多个接口. 接口体中包含常量定义和方法定义,接口中只进行方法的声明,不提供方法的实现. 类似建立类的继承关系 ...

  10. 201777010217-金云馨《面向对象程序设计Java》第八周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

随机推荐

  1. sql 代码优化

    1. where 执行顺序:右→左,筛选多的放右边:计算难度小的放右边,sql老版本(只在基于规则的优化器中有效,新版本基于代价不存在这个问题): 2. 少用子查询: 3. union快,表结构得一致 ...

  2. 经典损失函数:交叉熵(附tensorflow)

    每次都是看了就忘,看了就忘,从今天开始,细节开始,推一遍交叉熵. 我的第一篇CSDN,献给你们(有错欢迎指出啊). 一.什么是交叉熵 交叉熵是一个信息论中的概念,它原来是用来估算平均编码长度的.给定两 ...

  3. [C1W3] Neural Networks and Deep Learning - Shallow neural networks

    第三周:浅层神经网络(Shallow neural networks) 神经网络概述(Neural Network Overview) 本周你将学习如何实现一个神经网络.在我们深入学习具体技术之前,我 ...

  4. django-订单并发处理--悲观锁和乐观锁

    冲突比较少的时候,使用乐观锁. 冲突比较多的时候,使用悲观锁. (1)     悲观锁 select * from df_goods_sku where id=17 for update; 悲观锁获取 ...

  5. NG-ZORRO 使用相关

    Upload上传 import { Component, Input, Output, EventEmitter, Inject } from '@angular/core'; import { Nz ...

  6. go 基本语法

    ====type==== import ( "fmt" ) func main() { type bigint byte //定义类型 var a bigint fmt.Print ...

  7. 洛谷P3206 [HNOI2010]城市建设

    神仙题 题目大意: 有一张\(n\)个点\(m\)条边的无向联通图,每次修改一条边的边权,问每次修改之后这张图的最小生成树权值和 话说是不是\(cdq\)题目都可以用什么数据结构莽过去啊-- 这道题目 ...

  8. Visual Studio 2015 Tools for Unity使用基础

    Unity4.x编辑器侧 具体版本号:Visual Studio 2015 Tools for Unity 3.7.0.1 该插件在:Microsoft Visual Studio Tools for ...

  9. 爬虫——控制台抓包和requests.post()发送请求

    控制台抓包 打开方式及常用选项 1.打开浏览器,F12打开控制台,找到Network选项卡 2.控制台常用选项 1.Network: 抓取网络数据包 1.ALL: 抓取所有的网络数据包 2.XHR:抓 ...

  10. FFmpeg 是什么?

    笔者才开始学习音视频开发,主要是通过阅读刘歧.赵文杰编著的<FFmpeg从入门到精通>以及雷霄骅博士博客总结写的入门心得体会. 官方文档资料 FFmpeg官方文档:https://ffmp ...