传统企业如果建立网站福建省网站备案
news/
2025/10/5 4:02:19/
文章来源:
传统企业如果建立网站,福建省网站备案,临沂做网络优化的公司,微信商户平台介绍 方法的多态
多态是在继承#xff0c;重载#xff0c;重写的基础上实现的
我们可以看看这个代码
package b;public class main_ {public static void main(String[] args) {
// graduate granew graduate();
// gra.cry();//这个时候#xff0c;子类的cry方法就重写…介绍 方法的多态
多态是在继承重载重写的基础上实现的
我们可以看看这个代码
package b;public class main_ {public static void main(String[] args) {
// graduate granew graduate();
// gra.cry();//这个时候子类的cry方法就重写了父类的方法aa anew aa();System.out.println(a.sun(1,2,3));System.out.println(a.sun(1,3));}}
class father{//父类。private void say() {System.out.println(b say()方法被调用);}}
class aa extends father_{//子类继承父类public int sun(int n1,int n2) {//和下面的sum构成方法重载return n1n2;}public int sun(int n1,int n2,int n3) {//和下面的sum构成方法重载return n1n2n3;}} 用方法的重载
方法的重写 我现在在子类和父类中都加上say方法并创建对象调用虽然都是say 方法但调用的对象不同
package b;public class main_ {public static void main(String[] args) {
// graduate granew graduate();
// gra.cry();//这个时候子类的cry方法就重写了父类的方法aa anew aa();System.out.println(a.sun(1,2,3));System.out.println(a.sun(1,3));father bnew father();b.say();a.say();}}
class father{//父类。public void say() {System.out.println(b say()方法被调用);}}
class aa extends father_{//子类继承父类public int sun(int n1,int n2) {//和下面的sum构成方法重载return n1n2;}public int sun(int n1,int n2,int n3) {//和下面的sum构成方法重载return n1n2n3;}public void say() {System.out.println(a say()方法被调用);}}
多态的具体表现。 我们先来看看编译类型和运行类型
编译时类型也被称为静态类型是变量在声明时的类型或者可以理解为是引用的类型。编译时类型在编译期确定并且在程序运行过程中不会发生改变。编译器在编译时就会检查对应的类型规则。 Animal animal new Dog(); // 这里animal的编译时类型就是Animal 运行时类型也被称为动态类型在程序运行过程中动态绑定的类型即实际的对象类型。运行时类型可能会在运行期改变具体的类型是在运行时确定的。、 Animal animal new Dog(); // 这里animal的运行时类型就是Dog animal new Cat(); // 这里animal的运行时类型变为Cat 在堆栈中的 在Animal myDog new Dog();这句代码中涉及到了两部分的内存分配堆内存和栈内存他们的用途和特性各不相同。 1. 堆内存Heap: 这是存放所有对象实例以及数组的地方。在Java中通过new关键字创建的对象或数组都会在堆中分配内存。所以new Dog()创建的新的Dog对象就存放在堆内存中。 2. 栈内存Stack存放了基本类型的变量int, double, float, boolean, char等和对象引用变量。每个线程运行时都有自己的栈栈中的数据只在当前线程中有效。所以myDog是一个引用类型的变量它存放在栈内存中。它持有的是堆内存中的Dog对象的引用可以理解为指向堆内存中Dog对象的地址。 因此Animal myDog new Dog();这句代码一个Dog类型的对象实例被创建在堆内存中myDog这个引用变量被创建在栈内存中并且myDog持有了这个Dog实例的引用。这样通过myDog, 我们就可以指向和操作这个Dog实例了。 这种处理方式的一个重要理解是当myDog的作用域结束或者被设为null只是栈内存中的引用消失了但是堆内存中的Dog对象还在除非没有其他的引用指向这个Dog对象那它就会被认为是垃圾等待垃圾回收器在恰当的时候删除它。 真正理解 在这段代码Animal myDog new Dog();中Animal是一个类在Java中被用作数据类型。在这个上下文中它标识了myDog引用变量应该引用的对象类型。它并不直接占据堆或栈中的空间它存在于源代码以及编译后的字节码中。 具体的说Animal是一个reference(引用)类型而myDog是一个reference(引用)变量它的类型就是Animal。myDog变量存储在栈内存里而真正的对象实例new Dog()则存储在堆内存里。 Animal的存在影响的是myDog这个引用变量可以指向堆内存中的哪些对象。准确地说myDog可以指向堆内存中的Animal对象也可以指向任何一个Animal子类的对象如这里的Dog对象。 因此Animal并不直接占据内存而是确定了myDog引用变量可以引用哪种类型的对象。同时在编译期它也决定了可以通过myDog变量调用哪些方法和访问哪些字段。 多态代码
public class Animal {public void sound(){System.out.println(动物发出声音);}
}public class Dog extends Animal {public void sound(){System.out.println(汪汪汪);}
}public class Cat extends Animal {public void sound(){System.out.println(喵喵喵);}
}public class Main {public static void main(String[] args) {Animal myDog new Dog();Animal myCat new Cat();myDog.sound();myCat.sound();}
}
多态的动物 小提示
在java中 public void feed(Dog dog,Bone bone)其中的Dog dog,Bone bone是什么 在这个方法定义中: - public void feed(Dog dog, Bone bone) - feed是方法名 - public表示该方法可在任何位置访问 - void表示该方法没有返回值 - Dog dog, Bone bone 是该方法的参数(parameters) - Dog表示参数的类型为Dog类 - dog是参数名,表示传入的实参对象会以dog这个名字在方法内访问 - Bone bone表示下一个参数的类型为Bone类,名称为bone 所以简单总结: - Dog dog, Bone bone定义了这个feed方法需要两个参数 - 第一个参数是Dog类型,名称为dog - 第二个参数是Bone类型,名称为bone - 这两个参数在方法内通过dog和bone这个名字来访问传入的实参对象 所以这个方法定义表示,feed方法需要传入两个对象,一个是Dog类型,一个是Bone类型,然后在方法内部就可以通过dog和bone来操作这两个对象了。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/927845.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!