李瑞红201771010111

实验六继承定义与使用

实验时间 2018-9-2

第一部分:理论知识

第五章

1.类、超类和子类

5.2 Object:所有类的超类

5.3 泛型数组列表

5.4 对象包装器和自动打包

5.5 参数数量可变的方法

5.6 枚举类

5.7 继承设计的技巧

5.1 类、超类和子类

5.2 Object:所有类的超类

5.3 泛型数组列表

5.4 对象包装器和自动打包

5.5 参数数量可变的方法

5.6 枚举类

5.7 继承设计的技巧

1.继承(继承(inheritance

 继承:用已有类来构建新类的一种机制。当定义了一个新类继承了一个类时,这个新类就继承了这个类的方法和域,同时在新类中添加新的方法和域以适应新的情况。

 继承是Java程序设计中的一项核心技术, 也是面向对象特征之一。

2.继承的特点

 a.具有层次结构 b.子类继承了父类的域和方法

3.继承的优点

 a.代码可重用性 b.父类的域和方法可用于子类设计应用程序变得更加简单 c.可以轻松定义子类

4.类、超类和子类

 a.类继承的格式:class 新类名 extends 已有类名 b.已有类称为:超类(superclass)、基类(base class或父类(parent class、基类(base class).

来自系统类库用户自定义类

 c.新类称作:子类(subclass)、派生类(derivedclass)或孩子类(child class、派生类(derived

class)或孩子类(child class

 d.一般来说,子类比超类拥有的功能更加丰富。

注意:1.子类不能直接访问超类的私有域,必须和其他方法一样、子类不能直接访问超类的私有域,必须和其他方法一样——使用公有接口。使用公有接口。

2.通过扩展超类定义子类时,仅需要指出子类与超类的不同之处。在子类中可以增加域、增加方法或覆盖override)超类的方法,但绝对不能删除超类的任何域和方法。

3.super是一个指示编译器调用超类方法的特有关键字,它不是一个对象的引用,不能将super赋给另一个对象变量。

super关键字一般有两个用途:一是调用超类的方法(格式:super.方法名()),二是调用超类的构造公式(:super())

4.若子类构造器没有显式地调用超类的构造器,则将自动地调用超类默认构造器。如果超类只定义了带参数的构造器,若子类构造器没有显式地调用超类的构造器,则Java编译器将报告错误。

 5. 继承层次

  从一个超类扩展而来的类集合称为继承层次(inheritance hierarchy)。在继承层次中,从某个类到其祖先的路径被称为该类的继承链(inheritance chain),并且Java不支持多继承。

 6.多态性(polymorphism)

 a.多态性的概念(Polymorphism

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

超类中定义的域或方法,被子类继承之后,可以具有不同的数据类型或表现出不同的行为。

这使得同一个域或方法在超类及其各个子类中具有不同的语义。

超类中的方法在子类中可方法重写。

? 注意子类数组和超类数组的关系。p155的警告!!

继承层次结构中,每个子类对象也可视作是超类对象,因此,可以将子类对象赋给超类变量。

5.1.3 动态绑定

 动态绑定的概念

又称为运行时绑定。意思是说,程序在运行时会自动选择调用哪个方法。

调用对象方法的执行过程

首先,编译器检查对象的声明类型和方法名,搜索相应类(Son) 及其父类(Father)的“方法表”,找出所有访问属性

public method方法。方法。

接下来,编译器检查方法调用中提供的参数类型,找出一个完全匹配的方法,这个过程称为重载解析.

如果方法是privatestaticfinal修饰的,或者是构造器,那么编译器能准确地判断应该调用哪个方法,这称为

静态绑定

程序运行时,如果子类程序运行时,如果子类Son 中定义了 method() 的方法,则直接调用子类中的相应方法;则到其父类中寻找method()方法。

动态绑定中每次调用方法都要进行搜索,时间开销相当大。因此虚拟机预先为每个类创建了一个方法表,其中列出了所有方法的签名和实际调用的方法。

方法的名称和参数列表称为方法的签名

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

? 不允许继承的类称为 final类,在类的定义中用final修饰符加以说明。

在类的定义中用final修饰符加以说明。

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

? 如果一个类声明为final,属于它的方法会被自动设为final,但不包括域(如果域定义为final,在对象构造以

后,final域就不能再修改了)。

? String类是final类的一个例子。不能扩展该类。

5.1.5 强制类型转换

? 如果要把一个超类对象赋给一个子类对象变量,就必须进

行强制类型转换。其格式为:子类对象=(子类)(超类对象,就必须进行强制类型转换。其格式为:子类对象=(子类)(超类对象)

? 类型转换必须在继承层次内进行;而且在超类到子类转换

之前,应先使用 instanceof 操作符进行继承链检查。

abstract方法,只能声明,不能实现!

5.1.6 抽象类

? 观察类的继承层次结构,位于上层的类更具通用性,甚至可能更加抽象。从某种角度看,祖先类更加通用,人们只

将它作为派生其他类的基类,而不作为特定的实例类。

?为了提高程序的清晰度,包含一个或多个抽象方法的类本身必须被声明为抽象类。除了抽象方法之外,抽象类还可以包含具体数据和具体方法。

?抽象方法充当着占位的角色,它们的具体实现在子类中。扩展抽象类可以有两种选择:一种是在子类中实现部分抽象方法,这样就必须将子类也标记为抽象类;另一种是实现全部抽象方法,这样子类就可以不是抽象类。此外,类即使不含抽象方法,也可以将类声明为抽象类。

?抽象类不能被实例化,即不能创建对象,只能产生类。可以创建抽象类的对象变量,只是这个变量必须指向它的非抽象子类的对象。

访问修饰符

private protected public 默认

? 使用访问修饰符的原因:实现受限信息隐藏。

? 信息隐藏目的:

对类中任何实现细节的更改不会影响使用该类的代码

防止用户意外删除数据

易于使用

5.2 Object:所有类的超类

? Object类是Java中所有类的祖先——每一个类都由它扩展而来。在不给出超类的情况下,Java会自动把Object

作为要定义类的超类。

? 可以使用类型为Object的变量指向任意类型的对象。但要对它们进行专门的操作都要进行类型转换。

5.4 对象包装器与自动打包

? 所有基本数据类型都有着与之对应的预定义类,它们被称为对象包装器(wrapper)

5.6 枚举类

a.声明枚举类

public enum Grade { A, B, C, D, E };

它包括一个关键字enum,一个新枚举类型的名字Grade以及为Grade定义的一组值,这里的值既非整型,亦非字符型。

5.6.1 声明枚举类

? 枚举类说明

枚举类是一个类,它的隐含超类是java.lang.Enum

枚举值并不是整数或其它类型,是被声明的枚举类的自身实例,例如AGrade的一个实例。

枚举类不能有public修饰的构造函数,构造函数都是隐含private,编译器自动处理。

5.7 继承设计的技巧

将公共操作和域放在超类。

不要使用受保护的域。

使用继承实现“is-a”关系。

除非所有继承的方法都有意义,否则就不要使用继承。

除非所有继承的方法都有意义,否则就不要使用继承。

在覆盖方法时,不要改变预期的行为。

使用多态,而非类型信息。

不要过多地使用反射。

总结

? 封装、继承和多态是面向对象的主要特征

? 继承可提高代码的重用性,使用extends关键字来实现。除了构造方法之外,父类的所有方法和属性都被子类的对象继承.

? 多态性是不同的实例对象以不同的方式对相同的信息作出不同的表现

? 访问修饰符用于确定访问类成员的方式

? Java 常用修饰符有 staticfinalabstract

第二部分:实验部分

 1、实验目的与要求

(1) 理解继承的定义;

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

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

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

(5) 掌握类中4个成员访问权限修饰符的用途;

(6) 掌握抽象类的定义方法及用途;

(7)掌握Object类的用途及常用API;

(8) 掌握ArrayList类的定义方法及用法;

(9) 掌握枚举类定义方法及用途。

2、实验内容和步骤

实验1: 导入第5章示例程序,测试并进行代码注释。

测试程序1:

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

?   掌握子类的定义及用法;

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

  

 1 package inheritance;
 2
 3 /**
 4  * This program demonstrates inheritance.
 5  * @version 1.21 2004-02-21
 6  * @author Cay Horstmann
 7  */
 8 public class ManagerTest
 9 {
10    public static void main(String[] args)
11    {
12       // 构建管理者对象
13       Manager boss = new Manager("Carl Cracker", 80000, 1987, 12, 15);
14       boss.setBonus(5000);
15
16       Employee[] staff = new Employee[3];
17
18       // 用管理者和雇员对象填充数组
19
20       staff[0] = boss;
21       staff[1] = new Employee("Harry Hacker", 50000, 1989, 10, 1);
22       staff[2] = new Employee("Tommy Tester", 40000, 1990, 3, 15);
23
24       // 打印所有员工对象的信息
25       for (Employee e : staff)
26          System.out.println("name=" + e.getName() + ",salary=" + e.getSalary());
27    }
28 }
 1 package inheritance;
 2
 3 import java.time.*;
 4
 5 public class Employee
 6 {
 7    private String name;
 8    private double salary;
 9    private LocalDate hireDay;//构建三个public对象//
10
11    public Employee(String name, double salary, int year, int month, int day)
12    {
13       this.name = name;
14       this.salary = salary;
15       hireDay = LocalDate.of(year, month, day);
16    }
17
18    public String getName()
19    {
20       return name;
21    }
22
23    public double getSalary()
24    {
25       return salary;
26    }
27
28    public LocalDate getHireDay()
29    {
30       return hireDay;
31    }
32
33    public void raiseSalary(double byPercent)
34    {
35       double raise = salary * byPercent / 100;
36       salary += raise;
37    }
38 }
 1 package inheritance;
 2 //关键字extends表示继承,表明正在构造一个新类派生于一个已经存在的类//
 3 public class Manager extends Employee
 4 {
 5    private double bonus;
 6
 7    /**
 8     * @param name the employee‘s name
 9     * @param salary the salary
10     * @param year the hire year
11     * @param month the hire month
12     * @param day the hire day
13     */
14    public Manager(String name, double salary, int year, int month, int day)
15    {//调用超类中含有的参数的构造器。//
16       super(name, salary, year, month, day);
17       bonus = 0;
18    }
19
20    public double getSalary()
21    {//子类要想访问超类中的方法用关键字super//
22       double baseSalary = super.getSalary();
23       return baseSalary + bonus;
24    }
25
26    public void setBonus(double b)
27    {
28       bonus = b;
29    }
30 }

理解并总结OO风格程序构造特点,理解Employee和Manager类的关系子类的用途

对于面向对象风格程序构造特点,大体有四个,即:抽象、封装、继承、多态。

继承:简单理解就是代码复用,把重复使用的代码精简掉的一种手段。封装:就是把一部分或全部属性和部分功能(函数)对外界屏蔽。多态:没有继承就没有多态,继承是多态的前提。虽然继承自同一父类,但是相应的操作却各不相同,这叫多态。

Employee和Manager使用extends关键字完成继承关系。用父类进行声明,子类进行构造。

测试程序2:

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

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

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

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

 1 package abstractClasses;
 2
 3 /**
 4  * This program demonstrates abstract classes.
 5  * @version 1.01 2004-02-21
 6  * @author Cay Horstmann
 7  */
 8 public class PersonTest//主类//
 9 {
10    public static void main(String[] args)
11    {
12       Person[] people = new Person[2];
//用Employee类和Student类填充people数组//
1314 // fill the people array with Student and Employee objects 15 people[0] = new Employee("Harry Hacker", 50000, 1989, 10, 1); 16 people[1] = new Student("Maria Morris", "computer science"); 17 

18 // print out names and descriptions of all Person objects
 //打印出所有person类的名字和其他描述//
 19 for (Person p : people) 

20 System.out.println(p.getName() + ", " + p.getDescription()); 21  } 

22 }
 1 package abstractClasses;
 2
 3 public class Student extends Person
 4 {
 5    private String major;
 6
 7    /**
 8     * @param nama the student‘s name
 9     * @param major the student‘s major
10     */
11    public Student(String name, String major)
12    {
13       // pass n to superclass constructor
14       super(name);
15       this.major = major;
16    }
17
18    public String getDescription()
19    {
20       return "a student majoring in " + major;
21    }
22 }
package abstractClasses;

public abstract class Person
{
   public abstract String getDescription();
   private String name;//创建一个私有属行//

   public Person(String name)
   {
      this.name = name;
   }

   public String getName()
   {
      return name;
   }
}
 1 package abstractClasses;
 2
 3 import java.time.*;
 4
 5 public class Employee extends Person
 6 {
 7    private double salary;
 8    private LocalDate hireDay;
 9
10    public Employee(String name, double salary, int year, int month, int day)
11    {
12       super(name);
13       this.salary = salary;
14       hireDay = LocalDate.of(year, month, day);
15    }
16
17    public double getSalary()
18    {
19       return salary;
20    }
21
22    public LocalDate getHireDay()
23    {
24       return hireDay;
25    }
26
27    public String getDescription()
28    {
29       return String.format("an employee with a salary of $%.2f", salary);
30    }
31
32    public void raiseSalary(double byPercent)
33    {
34       double raise = salary * byPercent / 100;
35       salary += raise;
36    }
37 }

测试程序3:

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

?   掌握Object类的定义及用法;

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

 1 package equals;
 2
 3 /**
 4  * This program demonstrates the equals method.
 5  * @version 1.12 2012-01-26
 6  * @author Cay Horstmann
 7  */
 8 public class EqualsTest
 9 {
10    public static void main(String[] args)
11    {
12       Employee alice1 = new Employee("Alice Adams", 75000, 1987, 12, 15);
13       Employee alice2 = alice1;
14       Employee alice3 = new Employee("Alice Adams", 75000, 1987, 12, 15);
15       Employee bob = new Employee("Bob Brandson", 50000, 1989, 10, 1);
16
17       System.out.println("alice1 == alice2: " + (alice1 == alice2));
18
19       System.out.println("alice1 == alice3: " + (alice1 == alice3));
20
21       System.out.println("alice1.equals(alice3): " + alice1.equals(alice3));
22
23       System.out.println("alice1.equals(bob): " + alice1.equals(bob));
24
25       System.out.println("bob.toString(): " + bob);
26
27       Manager carl = new Manager("Carl Cracker", 80000, 1987, 12, 15);
28       Manager boss = new Manager("Carl Cracker", 80000, 1987, 12, 15);
29       boss.setBonus(5000);//子类中赋初值为空//
30       System.out.println("boss.toString(): " + boss);
31       System.out.println("carl.equals(boss): " + carl.equals(boss));
32       System.out.println("alice1.hashCode(): " + alice1.hashCode());
33       System.out.println("alice3.hashCode(): " + alice3.hashCode());
34       System.out.println("bob.hashCode(): " + bob.hashCode());
35       System.out.println("carl.hashCode(): " + carl.hashCode());
36    }
37 }
 1 package equals;
 2
 3 public class Manager extends Employee
 4 {
 5    private double bonus;
 6
 7    public Manager(String name, double salary, int year, int month, int day)
 8    {
 9       super(name, salary, year, month, day);
10       bonus = 0;
11    }
12
13    public double getSalary()
14    {
15       double baseSalary = super.getSalary();
16       return baseSalary + bonus;
17    }
18
19    public void setBonus(double bonus)
20    {
21       this.bonus = bonus;
22    }
23
24    public boolean equals(Object otherObject)
25    {
26       if (!super.equals(otherObject)) return false;
27       Manager other = (Manager) otherObject;
28       // super.equals checked that this and other belong to the same class
29       return bonus == other.bonus;
30    }
31
32    public int hashCode()
33    {
34       return java.util.Objects.hash(super.hashCode(), bonus);
35    }
36
37    public String toString()
38    {
39       return super.toString() + "[bonus=" + bonus + "]";
40    }
41 }
 1 package equals;
 2
 3 import java.time.*;
 4 import java.util.Objects;
 5
 6 public class Employee
 7 {
 8    private String name;
 9    private double salary;
10    private LocalDate hireDay;
11
12    public Employee(String name, double salary, int year, int month, int day)
13    {
14       this.name = name;
15       this.salary = salary;
16       hireDay = LocalDate.of(year, month, day);
17    }
18
19    public String getName()
20    {
21       return name;
22    }
23
24    public double getSalary()
25    {
26       return salary;
27    }
28
29    public LocalDate getHireDay()
30    {
31       return hireDay;
32    }
33
34    public void raiseSalary(double byPercent)
35    {
36       double raise = salary * byPercent / 100;
37       salary += raise;
38    }
39
40    public boolean equals(Object otherObject)
41    {
42       // a quick test to see if the objects are identical
43       if (this == otherObject) return true;
44
45       // must return false if the explicit parameter is null
46       if (otherObject == null) return false;
47
48       // if the classes don‘t match, they can‘t be equal
49       if (getClass() != otherObject.getClass()) return false;
50
51       // now we know otherObject is a non-null Employee
52       Employee other = (Employee) otherObject;
53
54       // test whether the fields have identical values
55       return Objects.equals(name, other.name) && salary == other.salary && Objects.equals(hireDay, other.hireDay);
56    }
57
58    public int hashCode()
59    {
60       return Objects.hash(name, salary, hireDay);
61    }
62
63    public String toString()
64    {
65       return getClass().getName() + "[name=" + name + ",salary=" + salary + ",hireDay=" + hireDay
66             + "]";
67    }
68 }

测试程序4:

?   在elipse IDE中调试运行程序5-11(教材182页),结合程序运行结果理解程序;

?   掌握ArrayList类的定义及用法;

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

 1 package arrayList;
 2
 3 import java.util.*;
 4
 5 /**
 6  * This program demonstrates the ArrayList class.
 7  * @version 1.11 2012-01-26
 8  * @author Cay Horstmann
 9  */
10 public class ArrayListTest
11 {
12    public static void main(String[] args)
13    {
14       // fill the staff array list with three Employee objects
15       ArrayList<Employee> staff = new ArrayList<>();
16
17       staff.add(new Employee("Carl Cracker", 75000, 1987, 12, 15));
18       staff.add(new Employee("Harry Hacker", 50000, 1989, 10, 1));
19       staff.add(new Employee("Tony Tester", 40000, 1990, 3, 15));
20
21       // raise everyone‘s salary by 5%
22       for (Employee e : staff)
23          e.raiseSalary(5);
24
25       // print out information about all Employee objects
26       for (Employee e : staff)
27          System.out.println("name=" + e.getName() + ",salary=" + e.getSalary() + ",hireDay="
28                + e.getHireDay());
29    }
30 }
 1 package arrayList;
 2
 3 import java.time.*;
 4
 5 public class Employee
 6 {
 7    private String name;
 8    private double salary;
 9    private LocalDate hireDay;
10
11    public Employee(String name, double salary, int year, int month, int day)
12    {
13       this.name = name;
14       this.salary = salary;
15       hireDay = LocalDate.of(year, month, day);
16    }
17
18    public String getName()
19    {
20       return name;
21    }
22
23    public double getSalary()
24    {
25       return salary;
26    }
27
28    public LocalDate getHireDay()
29    {
30       return hireDay;
31    }
32
33    public void raiseSalary(double byPercent)
34    {
35       double raise = salary * byPercent / 100;
36       salary += raise;
37    }
38 }

测试程序5:

?   编辑、编译、调试运行程序5-12(教材189页),结合运行结果理解程序;

?   掌握枚举类的定义及用法;

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

 1 package enums;
 2
 3 import java.util.*;
 4
 5 /**
 6  * This program demonstrates enumerated types.
 7  * @version 1.0 2004-05-24
 8  * @author Cay Horstmann
 9  */
10 public class EnumTest//主类//
11 {
12    public static void main(String[] args)
13    {
14       Scanner in = new Scanner(System.in);
15       System.out.print("Enter a size: (SMALL, MEDIUM, LARGE, EXTRA_LARGE) ");
16       String input = in.next().toUpperCase();//字符串转换为大写//
17       Size size = Enum.valueOf(Size.class, input);
18       System.out.println("size=" + size);
19       System.out.println("abbreviation=" + size.getAbbreviation());
20       if (size == Size.EXTRA_LARGE)
21          System.out.println("Good job--you paid attention to the _.");
22    }
23 }
24
25 enum Size//枚举类型(都是enum的子类)//
26 {
27    SMALL("S"), MEDIUM("M"), LARGE("L"), EXTRA_LARGE("XL");//传入参数//
28
29    private Size(String abbreviation) { this.abbreviation = abbreviation; }
30    public String getAbbreviation() { return abbreviation; }
31
32    private String abbreviation;
33 }

实验2编程练习1

?   定义抽象类Shape:

属性:不可变常量double PI,值为3.14;

方法:public double getPerimeter();public double getArea())。

?   让Rectangle与Circle继承自Shape类。

?   编写double sumAllArea方法输出形状数组中的面积和和double sumAllPerimeter方法输出形状数组中的周长和。

?   main方法中

1)输入整型值n,然后建立n个不同的形状。如果输入rect,则再输入长和宽。如果输入cir,则再输入半径。

2) 然后输出所有的形状的周长之和,面积之和。并将所有的形状信息以样例的格式输出。

3) 最后输出每个形状的类型与父类型,使用类似shape.getClass()(获得类型),shape.getClass().getSuperclass()(获得父类型);

思考sumAllArea和sumAllPerimeter方法放在哪个类中更合适?

输入样例:

 1 3
 2
 3 rect
 4
 5 1 1
 6
 7 rect
 8
 9 2 2
10
11 cir
12
13 1

输出样例:

18.28

8.14

[Rectangle [width=1, length=1], Rectangle [width=2, length=2], Circle [radius=1]]

class Rectangle,class Shape

class Rectangle,class Shape

class Circle,class Shape

import java.util.Scanner;

public class Work
{

    public static void main(String[] args)
    {
        Scanner in = new Scanner(System.in);
        String rect = "rect";
        String cir = "cir";
        System.out.print("请输入所需图形的形状个数:");
        int n = in.nextInt();
        shape[] count = new shape[n];
        for(int i=0;i<n;i++)
        {
            System.out.println("请输入图形形状:");
            String input = in.next();
            if(input.equals(rect))
            {
                double length = in.nextDouble();
                double width = in.nextDouble();
                System.out.println("长方形:"+"长:"+length+"  宽:"+width);
                count[i] = new Rect(length,width);
            }
            if(input.equals(cir))
            {
                double radius = in.nextDouble();
                System.out.println("圆:"+"半径:"+radius);
                count[i] = new Cir(radius);
            }
        }
        Work c = new Work();
        System.out.println(c.sumAllPerimeter(count));
        System.out.println(c.sumAllArea(count));
        for(shape s:count)
        {

            System.out.println(s.getClass()+",  "+s.getClass().getSuperclass());
        }
    }
public double sumAllArea(shape count[])
    {
         double sum = 0;
         for(int i = 0;i<count.length;i++)
             sum+= count[i].getArea();
         return sum;
    }

    public double sumAllPerimeter(shape count[])
    {
         double sum = 0;
         for(int i = 0;i<count.length;i++)
             sum+= count[i].getPerimeter();
         return sum;
    }

}
1 public abstract class shape
2  {
3      double PI = 3.14;
4      public abstract double  getPerimeter();
5      public abstract double  getArea();
6  }
public class Rect extends shape
{
    private double width;
    private double length;
    public Rect(double w,double l)
    {
        this.width = w;
        this.length = l;
    }
    public double getPerimeter()
    {
        double Perimeter = 2*(length+width);
        return Perimeter;
    }
    public double getArea()
    {
        double Area = length*width;
        return Area;
    }
}
 1 public class Cir extends shape
 2 {
 3     private double radius;
 4
 5     public Cir(double radius2) {
 6         // TODO Auto-generated constructor stub
 7     }
 8     public double getPerimeter()
 9     {
10         double Perimeter=2*PI*radius;
11         return Perimeter;
12     }
13     public double getArea()
14     {
15         double Area=PI*radius*radius;
16         return Area;
17     }
18 }

结果

实验3编程练习2

编制一个程序,将身份证号.txt 中的信息读入到内存中,输入一个身份证号或姓名,查询显示查询对象的姓名、身份证号、年龄、性别和出生地。

实验代码

  1 import java.io.BufferedReader;
  2 import java.io.File;
  3 import java.io.FileInputStream;
  4 import java.io.FileNotFoundException;
  5 import java.io.IOException;
  6 import java.io.InputStreamReader;
  7 import java.util.ArrayList;
  8 import java.util.Scanner;
  9
 10 public class Test{
 11     private static ArrayList<Person> Personlist;
 12     public static void main(String[] args) {
 13         Personlist = new ArrayList<>();
 14         Scanner scanner = new Scanner(System.in);
 15         File file = new File("E:\\WPS Office\\身份证号.txt");
 16         try {
 17             FileInputStream fis = new FileInputStream(file);
 18             BufferedReader in = new BufferedReader(new InputStreamReader(fis));
 19             String temp = null;
 20             while ((temp = in.readLine()) != null) {
 21
 22                 Scanner linescanner = new Scanner(temp);
 23
 24                 linescanner.useDelimiter(" ");
 25                 String name = linescanner.next();
 26                 String ID = linescanner.next();
 27                 String sex = linescanner.next();
 28                 String age = linescanner.next();
 29                 String birthplace =linescanner.nextLine();
 30                 Person Person = new Person();
 31                 Person.setname(name);
 32                 Person.setID(ID);
 33                 Person.setsex(sex);
 34                 Person.setage(age);
 35                 Person.setbirthplace(birthplace);
 36                 Personlist.add(Person);
 37
 38             }
 39         } catch (FileNotFoundException e) {
 40             System.out.println("查找不到信息");
 41             e.printStackTrace();
 42         } catch (IOException e) {
 43             System.out.println("信息读取有误");
 44             e.printStackTrace();
 45         }
 46         boolean isTrue = true;
 47         while (isTrue) {
 48
 49             System.out.println("1.按姓名查找");
 50             System.out.println("2.按身份证号查找");
 51             System.out.println("3.退出");
 52             int nextInt = scanner.nextInt();
 53             switch (nextInt) {
 54             case 1:
 55                 System.out.println("请输入姓名:");
 56                 String Personname = scanner.next();
 57                 int nameint = findPersonByname(Personname);
 58                 if (nameint != -1) {
 59                     System.out.println("查找信息为:姓名:"
 60                             + Personlist.get(nameint).getname() + "    身份证号:"
 61                             + Personlist.get(nameint).getID() +"    年龄:"
 62                             +Personlist.get(nameint).getage()   +"    性别:"
 63                             +Personlist.get(nameint).getsex()+"  出生地:"
 64                             +Personlist.get(nameint).getbirthplace()
 65                             );
 66                 } else {
 67                     System.out.println("此人不存在!");
 68                 }
 69                 break;
 70             case 2:
 71                 System.out.println("请输入身份证号");
 72                 String PersonID = scanner.next();
 73                 int IDint = findPersonByID(PersonID);
 74                 if (IDint != -1) {
 75                     System.out.println("查找信息为:姓名:"
 76                             + Personlist.get(IDint).getname() + "    身份证号:"
 77                             + Personlist.get(IDint).getID() +"    年龄:"
 78                             +Personlist.get(IDint).getage()   +"    性别:"
 79                             +Personlist.get(IDint).getsex()+"  出生地:"
 80                             +Personlist.get(IDint).getbirthplace()
 81                             );
 82                 } else {
 83                     System.out.println("此人不存在!");
 84                 }
 85                 break;
 86             case 3:
 87                 isTrue = false;
 88                 System.out.println("退出程序!");
 89                 break;
 90             default:
 91                 System.out.println("输入有误");
 92             }
 93         }
 94     }
 95
 96     private static int findPersonByID(String personID) {
 97         // TODO Auto-generated method stub
 98         return 0;
 99     }
100
101     private static int findPersonByname(String personname) {
102
103         return 0;
104     }
105
106     public static int findStudentByname(String name) {
107         int flag = -1;
108         int a[];
109         for (int i = 0; i < Personlist.size(); i++) {
110             if (Personlist.get(i).getname().equals(name)) {
111                 flag= i;
112             }
113         }
114         return flag;
115     }
116
117     public static int findStudentByID(String ID) {
118         int flag = -1;
119
120         for (int i = 0; i < Personlist.size(); i++) {
121             if (Personlist.get(i).getID().equals(ID)) {
122                 flag = i;
123             }
124         }
125         return flag;
126     }
127 }
 1 public class Person {
 2 private String name;
 3 private String ID;
 4 private String age;
 5 private String sex;
 6 private String birthplace;
 7
 8 public String getname() {
 9 return name;
10 }
11 public void setname(String name) {
12 this.name = name;
13 }
14 public String getID() {
15 return ID;
16 }
17 public void setID(String ID) {
18 this.ID= ID;
19 }
20 public String getage() {
21 return age;
22 }
23 public void setage(String age) {
24 this.age= age;
25 }
26 public String getsex() {
27 return sex;
28 }
29 public void setsex(String sex) {
30 this.sex= sex;
31 }
32 public String getbirthplace() {
33 return birthplace;
34 }
35 public void setbirthplace(String birthplace) {
36 this.birthplace= birthplace;
37 }
38
39 }

结果

总结:

在这周的学习中,我学会了面向对象的特征之一继承的相关知识。在后面的两个实验中,我了解了在父类下定义子类的方法程序以及其中的注意点,比如子类会继承父类的所有方法和域,我体会到继承的优点,它可以轻松定义子类,使得设计应用程序更加简单。前面的实验要求进行注解,通过这种方式,感觉读代码理解更深,不过掌握的英语知识太少,以后应该加强学习。

原文地址:https://www.cnblogs.com/LRHLRH123----/p/9750577.html

时间: 2024-08-29 05:38:00

李瑞红201771010111的相关文章

李瑞红 201771010111《面向对象程序设计(java)》第一周学习总结

李瑞红 201771010111<面向对象程序设计(java)>第一周学习总结 第一部分:课程准备部分 填写课程学习 平台注册账号, 平台名称 注册账号 博客园:www.cnblogs.com 3451487460 程序设计评测:https://pintia.cn/ [email protected] 代码托管平台:https://github.com/ 3451487490 中国大学MOOC:https://www.icourse163.org/ 3451487460 以下回答是或否 是否加

李瑞红201771010111第二周实验总结报告

第一部分:理论知识学习 本章主要内容是java的基本程序设计结构,包括以下几个方面的知识,(1)标识符.关键字.注释的相关知识:(2)数据类型:(3)变量:(4)运算符:(5)类型转换:(6)字符串:(7)输入输出:(8))控制流程:(9)大数值:(10)数组. 1.a,标识符只能由数字.字母.下划线和美元$符号组成,标识符不能以数字开头.b.关键字class表明java程序中的全部内容都包含在类里,class后面紧跟类名,源代码的文件名必须与公共类的名字相同,并用.java作为扩展名.c.与大

李瑞红201771010111第十周 学习总结

---恢复内容开始--- 实验十  泛型程序设计技术 实验时间 2018-11-1 第一部分:理论知识总结 1.泛型也称为参数化类型,就是在定义类.方法.接口时,通过类型参数指示将要处理的对象类型. .2.泛型程序设计:编写代码可以被很多不同类型的对象所重用. .3.一个泛型类就是具有一个或多个类型变量的类,即创建用类型作为参数的类. .4.Pair类引入了一个类型变量T,用尖括号(<>)括起来,并放在类名的后面.泛型类可以有多个类型变量. .5.类定义中的类型变量用于指定方法的返回类型以及域

201771010111 李瑞红 《第十二周学习总结》

实验十二  图形程序设计 实验时间 2018-11-14 第一部分:理论知识总结 1.Java的抽象口工具箱( Abstract WindowToolkit, AWT)包含在java.awt包中,它提供了许多用来设计GUI的组件类和容器类. 2.AWT库处理用户界面元素的方法:把图形元素的创建和行为委托给本地GUI工具箱进行处理. 3.Swing用户界面库是非基于对等体的GUI工具箱.Swing具有更丰富并且更方便的用户界面元素集合.Swing对底层平台的依赖很少,因此与平台相关的bug很少.S

201771010111 李瑞红 《第十七周学习总结》

实验十七  线程同步控制 实验时间 2018-12-10 一.理论部分 1.Java通过多线程的并发运行提高系统资源利用 率,改善系统性能. 2.假设有两个或两个以上的线程共享 某个对象,每个线程都调用了改变该对象类状态的方法,就会引起的不确定性. 3.多线程并发执行中的问题 多个线程相对执行的顺序是不确定的.线程执行顺序的不确定性会产生执行结果的不确定性.在多线程对共享数据操作时常常会产生这种不确定性. 4.多线程并发运行不确定性问题解决方案:引入线程同步机制. 5.线程的同步 -多线程并发运

李瑞钦+袁理想结对编程项目

李瑞钦+袁理想结对编程项目 项目要求: 1.用户注册功能.用户提供手机号码,点击注册将收到一个注册码,用户可使用该注册码完成注册: 2.用户完成注册后,界面提示设置密码,用户输入两次密码匹配后设置密码成功.密码6-10位,必须含大小写字母和数字.用户在登录状态下可修改密码,输入正确的原密码,再输入两次相同的新密码后修改密码成功: 3.密码设置成功后,跳转到选择界面,界面显示小学.初中和高中三个选项,用户点击其中之一后,提示用户输入需要生成的题目数量: 4.用户输入题目数量后,生成一张试卷(同一张

李秋红130705010066

《经济学科在美国》——李兴红

通化华辰药业 本篇文章主要讲了美国大学中经济学科的设置.美国大学的经济学教育.美国的经济学博士的教育模式在欧洲.中国生申请留学美国攻读经济学学位时应注意的事项等几个方面.读了这篇文章,我整体的感受是了解到了美国大学的经济学科的独特,特别是其经济学教育模式在全世界的名气,其主要的原因还是因为美国有独特的教育环境和优秀的教授.本文开始介绍了美国大学中的经济学科的设置,讲述了国内的金融和美国金融的区别,国内的金融主要研究的是货币银行学和国际金融,美国金融则研究的是公司金融和资产定价,在美国学本科经济学

狄慧201771010104《面向对象程序设计(java)》第十三周学习总结

实验十三  图形界面事件处理技术 实验时间 2018-11-22 一.知识点总结 1.AWT事件处理机制的概要: 1>监听器对象是一个实现了特定监听器接口的类的实例: 2>事件源是一个能够注册监听器对象并发送事件对象的对象: 3>当事件发生时,事件源将事件对象传递给所有注册的监听器: 4>监听器对象将利用事件对象中的信息决定如何对事件做出响应. 2.改变观感: 在默认情况下,Swing程序使用Metal观感,可以采用两种方式改变观感: 1>在Java安装的子目录jre/lib