黑马程序员——面对对象(多态 )

本文深入讲解Java中的多态概念,包括重载与覆盖的区别及应用,并通过实例演示如何使用多态进行灵活的对象操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

------- android培训java培训、期待与您交流! ----------

多态

多态是具有表现多种形态的能力的特征,语言具有根据对象的类型以不同方式处理之,特别是重载方法和继承类这种形式的能力。多态被认为是面向对象语言的必备特性。

 重载(overload),是发生在同一类中。
  标识一个函数除了函数名外,还有函数的参数(个数和类型)。也就是说,一个类中可以有两个或更多的函数,叫同一个名字而他们的参数不同。    
  他们之间毫无关系,是不同的函数,只是可能他们的功能类似,所以才命名一样,增加可读性,仅此而已!  
例如:
    
public class Test6 {
	//该方法接收一个整数
	public void method(int i) {
	}
	//该方法接收两个整数,方法名一致,就上面个方法构成了重载
	public void method(int i,int j) {
	}
}

  再说覆盖(override),是发生在子类中!也就是说必须有继承的情况下才有覆盖发生。
  
  我们知道继承一个类,也就有了父类了全部方法,如果你感到哪个方法不爽,功能要变,那就把那个函数在子类中重新实现一遍。  
  这样再调用这个方法的时候,就是执行子类中的过程了。父类中的函数就被覆盖了。(当然,覆盖的时候函数名和参数要和父类中完全一样,不然子类中方法对父类中的方法就不起任何作用,因为两者是两个函数,毫不关系)
例如:
	public class Animal {
		public void eat() {
			System.out.println("吃饭");
		}
	}

	public class Cat extends Animal {
		// 覆盖父类中的eat方法
		public void eat() {
			System.out.println("猫在吃饭");
		}

	}

1.Java语言允许某个类型的引用变量引用子类的实例,而且可以对这个引用变量进行类型转换。
Animal animal=new Dog();   //引用变量animal引用一个Animal子类Dog的实例
Dog dog=(Dog)animal;   //向下转型,把Animal类型转换为Dog类型
Creature creature=animal; //向上转型,把Animal类型转换为 Creature类型
animal=new Cat(); //引用变量animal引用另一个Animal子类Cat的实例
注:Creature这里指的是生物。
2.如果把引用变量转换为子类类型,称为向下转型,如果把引用变量转换为父类类型,称为向上转型。

3.在进行引用变量的类型转换时,会受到各种限制。而且在通过引用变量访问它所引用的实例的静态属性、静态
方法、实例属性、实例方法,以及从父类中继承的方法和属性时,Java虚拟机会采用不同的绑定机制。

4.成员变量、静态方法按照引用变量声明的类型静态绑定;实例方法按照引用变量引用的实例动态绑定。
例如:
public class Animal {
	public void eat() {
		System.out.println("吃饭");
	}
}
public class Cat extends Animal {
	// 覆盖父类中的eat方法
	public void eat() {
		System.out.println("猫在吃饭");
	}
}
public class Dog extends Animal {
	// 覆盖父类中的eat方法
	public void eat() {
		System.out.println("狗在吃饭");
	}
}

public class Test6 {
	//父类引用子类对象
	public static  void run(Animal animal) {
		//判断子类
		if(animal instanceof Dog){
			//将父类强转为子类
			Dog dog = (Dog) animal;
			dog.eat();
		}else if(animal instanceof Cat){
			Cat cat = (Cat) animal;
			cat.eat();
		}
	}
	public static void main(String[] i) {
		run(new Dog());  //运行结果为“狗在吃饭”
		run(new Cat());  //运行结果为“猫在吃饭”
	}
}

------- android培训java培训、期待与您交流! ----------


资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在本文中,我们将探讨如何通过 Vue.js 实现一个带有动画效果的“回到顶部”功能。Vue.js 是一款用于构建用户界面的流行 JavaScript 框架,其组件化和响应式设计让实现这种交互功能变得十分便捷。 首先,我们来分析 HTML 代码。在这个示例中,存在一个 ID 为 back-to-top 的 div 元素,其中包含两个 span 标签,分别显示“回到”和“顶部”文字。该 div 元素绑定了 Vue.js 的 @click 事件处理器 backToTop,用于处理点击事件,同时还绑定了 v-show 指令来控制按钮的显示与隐藏。v-cloak 指令的作用是在 Vue 实例渲染完成之前隐藏该元素,避免出现闪烁现象。 CSS 部分(backTop.css)主要负责样式设计。它首先清除了一些默认的边距和填充,对 html 和 body 进行了全屏布局,并设置了相对定位。.back-to-top 类则定义了“回到顶部”按钮的样式,包括其位置、圆角、阴影、填充以及悬停时背景颜色的变化。此外,与 v-cloak 相关的 CSS 确保在 Vue 实例加载过程中隐藏该元素。每个 .page 类代表一个页面,每个页面的高度设置为 400px,用于模拟多页面的滚动效果。 接下来是 JavaScript 部分(backTop.js)。在这里,我们创建了一个 Vue 实例。实例的 el 属性指定 Vue 将挂载到的 DOM 元素(#back-to-top)。data 对象中包含三个属性:backTopShow 用于控制按钮的显示状态;backTopAllow 用于防止用户快速连续点击;backSeconds 定义了回到顶部所需的时间;showPx 则规定了滚动多少像素后显示“回到顶部”按钮。 在 V
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值