一.实验目的
(1)掌握类的继承
(2)变量的继承和覆盖,方法的继承,重载和覆盖的实现;
二.实验的内容
(1)根据下面的要求实现圆类Circle。
1.圆类Circle的成员变量:radius表示圆的半径。
2.圆类Circle的方法成员:
Circle():构造方法,将半径置0
Circle(double r):构造方法,创建Circle对象时将半径初始化为r
double getRadius():获得圆的半径值
double getPerimeter():获得圆的周长
void disp():将圆的半径和圆的周长,圆的面积输出到屏幕
(2)继承第一题中的圆Circle类,派生圆柱体类Cylinder。要求如下:
1.圆柱体类Cylinder的成员变量:height表示圆柱体的高。
2.圆柱体类Cylinder的成员方法:
Cylinder(double r,double h)构造方法,创建Cylinder对象时将圆半径初始化为r,圆柱体高初始化为h。
double getHeight():获得圆柱体的高
double getVol():获得圆柱体的体积
void dispVol():将圆柱体的体积输出到屏幕
3.按照第二题的Cylinder类,接上键盘的输入值作为圆的半径和圆柱体的高,计算圆柱体的体积
实验代码:
import java.util.Scanner;
import static java.lang.Math.pow;
public class Circle {
double Radius=0;
Circle() {
double Radius=0;
}
private Circle(double r) {
this.Radius = r;
}
private double getRadius() {
return Radius;
}
private double getPerimeter() {
return 2*Radius*Math.PI;
}
private double gets() {
return pow(Radius,2)*Math.PI;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("输入半径:");
double r=sc.nextDouble();
Circle y=new Circle(r);
System.out.println("半径:"+y.getRadius());
System.out.println("周长:"+y.getPerimeter());
System.out.println("面积:"+y.gets());
}
}
import java.util.Scanner;
import static java.lang.Math.pow;
public class Cylinder extends Circle {
private double height;
private Cylinder(double r, double h) {
this.Radius=r;
this.height =h;
}
private double getHeight() {
return height;
}
private double getVol() {
return height*pow(Radius,2)*Math.PI;
}
public static void main(String[] args) {
System.out.print("输入圆柱体的的底面半径:");
Scanner cv=new Scanner(System.in);
double r=cv.nextDouble();
System.out.print("输入圆柱体的高:");
double h=cv.nextDouble();
Cylinder yz=new Cylinder(r,h);
System.out.println("圆柱体的高:"+yz.getHeight());
System.out.println("圆柱体的体积:"+yz.getVol());
}
}
总结
1、继承是多态的前提;子类可以继承父类的非私人的内容;
继承格式:public class 子类名称 extends 父类名称{}
2、重载:方法名称相同,参数列表不同
覆盖:方法名称和参数列表都相同
判断方法是否覆盖的一个方法是在定义方法前加上@Override
即可,如果报错则没有覆盖,反之则覆盖。
3、π的表示:Math.PI
4、学到的新的类:Circle,Cylinder类,题目中就有创建新的这两类
5、之前遇到的一个问题:super(),super是指向父类的引用,如果构造方法没有显示地调用父类的构造方法,super和this是相似的,但也有很大的区别;this是调用本类中的变量或者构造函数、方法,而super则是调用父类中的变量,构造方法或者构造函数。调用super()必须写在子类构造方法的第一行,否则编译不通过,this也是如此;具体差别看下图: