十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
首先是从Object父类继承来的equals方法,然后你28行又写了一个参数类型是CircleTest1的equals方法,这属于方法的重载,也就是说此时CircleTest1类里有两个重载的equals方法,而你18行传入的是Object类型,所以调用的是从父类Object继承而来的的equals方法,所以首先编译没问题,其次Object类里的equals方法写的是this == obj,而你18行比较的是两个不同对象,所以是false,21行调用的是子类重写的父类equals方法,执行的是子类重写的方法体,比较的是radius变量值,默认都是0,所以相等
新余ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!
下面将分别讲解重载与重写:
1、重载overloading
1) 方法重载是让类以统一的方式处理不同类型数据的一种手段。多个同名函数同时存在,具有不同的参数个数/类型。重载是一个类中多态性的一种表现。
2) Java的方法重载,就是在类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义。调用方法时通过传递给它们的不同参数个数和参数类型给它们的不同参数个数和参数类型给它们的不同参数个数和参数类型来决定具体使用哪个方法, 这就是多态性。
3) 重载的时候,方法名要一样,但是参数类型和个数不一样,返回值类型可以相同也可以不相同。无法以返回型别作为重载函数的区分标准。
示例代码:
public class Dog {
Dog()
{
this.bark();
}
void bark()//bark()方法是重载方法
{
System.out.println("no barking!");
this.bark("female", 3.4);
}
void bark(String m,double l)//注意:重载的方法的返回值都是一样的,
{
System.out.println("a barking dog!");
this.bark(5, "China");
}
void bark(int a,String n)//不能以返回值区分重载方法,而只能以“参数类型”和“类名”来区分
{
System.out.println("a howling dog");
}
public static void main(String[] args)
{
Dog dog = new Dog();
//dog.bark();
//dog.bark("male", "yellow");
//dog.bark(5, "China");
}
}
2、重写overriding
1) 父类与子类之间的多态性,对父类的函数进行重新定义。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。在Java中,子类可继承父类中的方法,而不需要重新编写相同的方法。但有时子类并不想原封不动地继承父类的方法,而是想作一定的修改,这就需要采用方法的重写。方法重写又称方法覆盖。
2) 若子类中的方法与父类中的某一方法具有相同的方法名、返回类型和参数表,则新方法将覆盖原有的方法。如需父类中原有的方法,可使用super关键字,该关键字引用了当前类的父类。
3) 子类函数的访问修饰权限不能少于父类的;
示例代码:
public class Base
{
void test(int i)
{
System.out.print(i);
}
void test(byte b)
{
System.out.print(b);
}
}
public class TestOverriding extends Base
{
void test(int i)
{
i++;
System.out.println(i);
}
public static void main(String[]agrs)
{
Base b=new TestOverriding();
b.test(0)
b.test((byte)0)
}
}
这时的输出结果是1 0,这是运行时动态绑定的结果。
final 和static 的方法不能被重写 但是静态的方法可以被重新定义
你那个不是重写 是重新定义 重新定义不属于多态范畴
所以他只看引用类型 但是java也强烈建议你千万不要用引用去访问静态变量或静态方法,因为那样你会逻辑混乱
你用的f其实就是子类型,根本没有多态的,就算是调用重写的非静态方法还是体现不出多态性
那么其调用的grow一定是重新定义的子类方法
然而
Amphibian.grow(f);
来说 你在grow参数里声明的是父类的引用 但是你却把一个子类实例传递进来
多态性在这体现了 首先调用的是父类的静态没疑问了 然而a.eat();出现了多态行为
父类引用指向子类对象 调用的是子类重写的方法
import java.util.*;
public class zilei{
public static void main(String arg[]){
System.out.println("请输入两个正整数:");
Scanner reader=new Scanner(System.in);
int a=reader.nextInt();
int b=reader.nextInt();
A aa;
B bb;
aa=new A();
bb=new B();
int d=aa.f(a,b);
System.out.println("最大公约数:" +d);
int k=bb.f(a,b);
System.out.println("最小公倍数:" +k);
}
}
class A {
public int f(int a,int b){
int r=a%b;
while(r!=0){
a=b;
b=r;
r=a%b;
}
return b;
}
}
class B extends A{
public int f(int a,int b){
int m=super.f(a, b);
return ((a*b)/m);
}
}
这里class B 的f(int a,int b)方法就重写了父类的相同方法。
重写: 重写方法必须和被重写方法具有 相同的 方法名、参数列表、和返回值类型。
必须和父类的参数列表相同为什么:
上面说的不错,是为了多态,重写是多态的必要条件之一,多态说白了就是程序执行前(包括编写代码时和编译.java源文件的时候)你调的是父类被重写这方法,真正在运行时(程序执行以后),实际当中,动态绑定(在运行期间真正的new出该对象来,对象内部有一个指针,指向该对象重写的写个方法),调用的是子类重写的这个方法。
方法的参数是形参,形参的作用是接收调用该方法时传过来的实参,形参属于局部变量,那么毫无疑问方法内部是要使用这些个参数做一些事情的,重写要求参数列表必须相同,如果不相同,那么你调父类被重写的这个方法,参数列表不同,那实际当中还执行子类这重写方法,那不矛盾么?内部不混乱了么?参数对不上号,人家重写方法内部要用这参数怎么办啊?
下面这个不太肯定,不过我还是说一下我的看法:
构造方法能不能被继承,new一个子类对象出来的时候,子类对象里面包含着一个父类对象,也就是说,父类对象的所有东西子类对象全部都拥有了,全部都继承下来了,但是有些东西你是有拥有权,没有使用权,比方说private的方法,构造方法是new一个对象的时候必然要调用的方法,初始化对象用的,这个方法比较特殊,不像一般的方法一样,是为了做一件事儿,它就是new对象时候调的方法,我认为构造方法还是继承下来了,但是你用不了,无法用子类对象的引用去调用构造方法。
就是重新的意思啊!方法重写和重载都是重新写该方法的内容,都要求方法名要相同,但是参数顺序、名字不同,这就是重写和重载,重写还必须是有继承关系的类才可以重写的!