8 面向对象(制作帮助文档,通过JDK提供的API学习了Math类,代码块,继承(继承子父成员访问特点,super关键字,方法重写))

来源:互联网 发布:迅雷快鸟网络异常 编辑:程序博客网 时间:2024/06/05 00:37

1:如何制作帮助文档(了解)

       (1)写一个类

       (2)加入文档注释

       (3)通过javadoc工具生成即可

              javadoc-d 目录 -author-version ArrayTool.java

        .目录:就可以写一个文件夹的路径

2:通过JDK提供的API学习了Math类(掌握)

       (1)API(ApplicationProgramming Interface)

              应用程序编程接口(帮助文档)

       (2)如何使用呢?

             

1:打开帮助文档2:点击显示,找到索引,看到输入框3:知道你要找谁?以Scanner举例4:在输入框里面输入Scanner,然后回车5:看包java.lang包下的类不需要导入,其他的全部需要导入。要导入:java.util.Scanner6:再简单的看看类的解释和说明,别忘了看看该类的版本7:看类的结构成员变量字段摘要 构造方法构造方法摘要 成员方法 方法摘要8:学习构造方法A:有构造方法就创建对象B:没有构造方法成员可能都是静态的9:看成员方法A:左边是否静态:如果静态,可以通过类名调用返回值类型:人家返回什么,你就用什么接收。B:右边看方法名:方法名称不要写错参数列表:人家要什么,你就给什么;人家要几个,你就给几个

       (3)Math类

              A:是针对数学进行操作的类

              B:没有构造方法,因为它的成员都是静态的

              C:产生随机数

                     publicstatic double random(): [0.0,1.0) 该值大于等于 0.0 且小于 1.0

              D:如何产生一个1-100之间的随机数

                     intnumber = (int)(Math.random()*100)+1;

              E:猜数字小游戏

/*猜数字小游戏(数据在1-100之间)分析:A:程序产生一个随机数。(被猜的)B:键盘录入数据。(你猜的)C:把你猜的和被猜的进行比较a:大了b:小了c:猜中了D:给出多次猜的机会,猜中就结束。while()循环,猜中就break*/import java.util.Scanner;class GuessNumber {public static void main(String[] args) {//程序产生一个随机数。(被猜的)int number = (int)(Math.random()*100)+1;//System.out.println(number);//给出多次猜的机会,猜中就结束。while(true) {//键盘录入数据。(你猜的)Scanner sc = new Scanner(System.in);System.out.println("请输入你要猜的数据(1-100):");int guessNumber = sc.nextInt();//把你猜的和被猜的进行比较if(guessNumber > number) {System.out.println("你猜的数据"+guessNumber+"大了");}else if(guessNumber < number) {System.out.println("你猜的数据"+guessNumber+"小了");}else {System.out.println("恭喜你,猜中了");break;}}}}


 

3:代码块(理解)

       (1)用{}括起来的代码。

       (2)分类:

              A:局部代码块

                     局部位置,用于限定变量的生命周期,及早释放,提高内存利用率。

              B:构造代码块

                     在类中的成员位置方法外,把多个构造方法中相同的代码可以放到这里,对对象进行初始化,每个构造方法执行前,首先执行构造代码块。

              C:静态代码块

                     对类的数据进行初始化,仅仅只执行一次。

D:同步代码块

       (3)静态代码块,构造代码块,构造方法的顺序问题?

              静态代码块 > 构造代码块 > 构造方法

静态代码块只执行一次  构造代码块每次调用构造方法都执行

      

4:继承(掌握)

       (1)把多个类中相同的成员给提取出来定义到一个独立的类中。然后让这多个类和该独立的类产生一个关系,

          这多个类就具备了这些内容。这个关系叫继承。

       (2)Java中如何表示继承呢?格式是什么呢?

              A:用关键字extends表示

              B:格式:

                     class子类名 extends 父类名 {}

       (3)继承的好处:

              A:提高了代码的复用性

              B:提高了代码的维护性

              C:让类与类产生了一个关系,是多态的前提

       (4)继承的弊端:

              A:让类的耦合性增强。这样某个类的改变,就会影响其他和该类相关的类。

                     原则:低耦合,高内聚。

                     耦合:类与类的关系

                     内聚:自己完成某件事情的能力

              B:打破了封装性

       (5)Java中继承的特点

              A:Java中类只支持单继承

              B:Java中可以多层(重)继承(继承体系)

       (6)继承的注意事项:

              A:子类不能继承父类的私有成员

              B:子类不能继承父类的构造方法,但是可以通过super去访问

              C:不要为了部分功能而去继承

       (7)什么时候使用继承呢?

              A:继承体现的是:is a的关系。

              B:采用假设法

.如果有两个类A,B。只要它们符合A是B的一种,或者B是A的一种,就可以考虑使用继承。

       (8)Java继承中的成员关系

              A:成员变量

                     a:子类的成员变量名称和父类中的成员变量名称不一样,正常访问

                     b:子类的成员变量名称和父类中的成员变量名称一样,这个怎么访问呢?

                            子类的方法访问变量的查找顺序:

                                   在子类方法的局部范围找,有就使用。

                                   在子类的成员范围找,有就使用。

                                   在父类的成员范围找,有就使用。

                                   找不到,就报错。

              B:构造方法

                     a:子类的构造方法默认会去访问父类的无参构造方法

                            因为子类会继承父类中的数据,可能还会使用父类的数据

   .所以,子类初始化之前,一定要先完成父类数据的初始化

   .PS:子类每一个构造方法的第一条语句默认都是:super();

                     b:父类中如果没有无参构造方法,怎么办?

                            子类通过super去明确调用带参构造

                            子类通过this调用本身的其他构造,但是一定会有一个去访问了父类的构造

                            让父类提供无参构造

PS:this(...)或者super(...)必须出现在第一条语句上,如果不是放在第一条语句上,

.就可能对父类的数据进行了多次初始化,所以必须放在第一条语句上

              C:成员方法

                     a:子类的成员方法和父类中的成员方法名称不一样,这个太简单

                     b:子类的成员方法和父类中的成员方法名称一样,这个怎么访问呢?

                            通过子类对象访问一个方法的查找顺序:

                                   在子类中找,有就使用

                                   在父类中找,有就使用

                                   找不到,就报错

       (9)方法重写

两个面试题:

              A:Override和Overload的区别?Overload是否可以改变返回值类型?

Override:方法重写

Overload:方法重载

方法重写:

       在子类中,出现和父类中一模一样的方法声明的现象。

      PS:方法重写的注意事项
A:父类中私有方法不能被重写
因为父类私有方法子类根本就无法继承
B:子类重写父类方法时,访问权限不能更低
最好就一致
C:父类静态方法,子类也必须通过静态方法进行重写
其实这个算不上方法重写,但是现象确实如此,因为静态和类相关,算不上重写,

子类重写父类方法的时候,最好声明一模一样。

方法重载:

       同一个类中,出现的方法名相同,参数列表不同的现象。



              B:this和super的区别和各自的作用?

     .this代表本类对应的引用。

                     super代表父类存储空间的标识(可以理解为父类引用,可以操作父类的成员)

 

                     使用

                     A:调用成员变量

                            this.成员变量 调用本类的成员变量

                            super.成员变量 调用父类的成员变量

                     B:调用构造方法

                            this(...)    调用本类的构造方法

                            super(...) 调用父类的构造方法

                     C:调用成员方法

                            this.成员方法 调用本类的成员方法

                            super.成员方法 调用父类的成员方法


       (10)数据初始化的面试题

              A:一个类的初始化过程

/*看程序写结果:A:成员变量就近原则B:this和super的问题this访问本类的成员super访问父类的成员C:子类构造方法执行前默认先执行父类的无参构造方法D:一个类的初始化过程成员变量进行初始化默认初始化显示初始化构造方法初始化结果:fuzi302010*/class Fu{public int num = 10;public Fu(){System.out.println("fu");}}class Zi extends Fu{public int num = 20;public Zi(){System.out.println("zi");}public void show(){int num = 30;System.out.println(num); //30System.out.println(this.num); //20System.out.println(super.num); //10}}class ExtendsTest {public static void main(String[] args) {Zi z = new Zi();z.show();}}


              B:子父类的构造执行过程

/*看程序写结果:A:一个类的静态代码块,构造代码块,构造方法的执行流程静态代码块 > 构造代码块 > 构造方法B:静态的内容是随着类的加载而加载静态代码块的内容会优先执行C:子类初始化之前先会进行父类的初始化结果是:静态代码块Fu静态代码块Zi构造代码块Fu构造方法Fu构造代码块Zi构造方法Zi*/class Fu {static {System.out.println("静态代码块Fu");}{System.out.println("构造代码块Fu");}public Fu() {System.out.println("构造方法Fu");}}class Zi extends Fu {static {System.out.println("静态代码块Zi");}{System.out.println("构造代码块Zi");}public Zi() {System.out.println("构造方法Zi");}}class ExtendsTest2 {public static void main(String[] args) {Zi z = new Zi();}}


              C:分层初始化

/*看程序写结果:A:成员变量的问题int x = 10; //成员变量是基本类型Student s = new Student(); //成员变量是引用类型B:一个类的初始化过程成员变量的初始化默认初始化显示初始化构造方法初始化C:子父类的初始化(分层初始化)先进行父类初始化,然后进行子类初始化。结果:YXYZ问题:虽然子类中构造方法默认有一个super()初始化的时候,不是按照那个顺序进行的。而是按照分层初始化进行的。它仅仅表示要先初始化父类数据,再初始化子类数据。*/class X {Y b = new Y();X() {System.out.print("X");}}class Y {Y() {System.out.print("Y");}}public class Z extends X {Y y = new Y();Z() {//superSystem.out.print("Z");}public static void main(String[] args) {new Z(); }}


       (11)案例:

              A:学生和老师案例

                     继承前

                     继承后

              B:猫狗案例的分析和实现

/*猫狗案例讲解先找到具体的事物,然后发现具体的事物有共性,才提取出一个父类。猫:成员变量:姓名,年龄,颜色构造方法:无参,带参成员方法:getXxx()/setXxx()eat()palyGame()狗:成员变量:姓名,年龄,颜色构造方法:无参,带参成员方法:getXxx()/setXxx()eat()lookDoor()共性:成员变量:姓名,年龄,颜色构造方法:无参,带参成员方法:getXxx()/setXxx()eat()把共性定义到一个类中,这个类的名字叫:动物。动物类:成员变量:姓名,年龄,颜色构造方法:无参,带参成员方法:getXxx()/setXxx()eat()猫:构造方法:无参,带参成员方法:palyGame()狗:构造方法:无参,带参成员方法:lookDoor()*///定义动物类class Animal {//姓名private String name;//年龄private int age;//颜色private String color;public Animal() {}public Animal(String name,int age,String color) {this.name = name;this.age = age;this.color = color;}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 String getColor() {return color;}public void setColor(String color) {this.color = color;}public void eat() {System.out.println("不要睡了,该吃饭了");}}//定义猫类class Cat extends Animal {public Cat() {}public Cat(String name,int age,String color) {super(name,age,color);}public void playGame() {System.out.println("猫玩英雄联盟");}}//定义狗类class Dog extends Animal {public Dog() {}public Dog(String name,int age,String color) {super(name,age,color);}public void lookDoor() {System.out.println("狗看家");}}//测试类class ExtendsTest5 {public static void main(String[] args) {//测试猫//方式1Cat c1 = new Cat();c1.setName("Tom");c1.setAge(3);c1.setColor("白色");System.out.println("猫的名字是:"+c1.getName()+";年龄是:"+c1.getAge()+";颜色是:"+c1.getColor());c1.eat();c1.playGame();System.out.println("---------------");//方式2Cat c2 = new Cat("杰瑞",5,"土豪金");System.out.println("猫的名字是:"+c2.getName()+";年龄是:"+c2.getAge()+";颜色是:"+c2.getColor());c2.eat();c2.playGame();//作业:测试狗}}


             

              

0 0
原创粉丝点击