Java的多态机制

简介: Java的多态机制

多态

1.概念

多态是面向对象的三大特征之一,指的是一种事物有多种形态,通过多态,我们可以提高程序的扩展力,降低程序的耦合度。

比如说有这样的一种场景:你养了小动物,小猫,小狗,小鸟,它们都是动物,每个小动物都要吃东西,我们可以设置它们都有吃的功能,但是它们吃的东西不一样,所以需要重写父类的方法。

多态对象只能调用父类中定义过的,然后子类中重写的方法,并不能调用子类的特有功能。


# 2.向上转型和向下转型 1.向上转型 子----->父(自动类型转换) 2.向下转型 父----->子(强制类型转换) **如果我们想要访问的方法是子类中特有的方法,我们就要做向下类型转换** ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/b07c5b41ba81405191f1390b507376cd.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASmF2YeiPnOm4n-eahOWtpuS5oOS5i-i3rw==,size_20,color_FFFFFF,t_70,g_se,x_16)
# 3.静态绑定和动态绑定(重点理解) Java程序有编译阶段和运行阶段 现在我通过一个例子,来简单说明一下 ```java public class AnimalTest{ public static void main(String[]args){ Animal a=new Cat(); Animal b=new Bird(); a.move(); } } class Animal{ // 移动的方法 public void move(){ System.out.println("动物在移动!!!"); } } // 鸟儿类,子类 public class Bird extends Animal{ // 重写父类的move方法 public void move(){ System.out.println("鸟儿在飞翔!!!"); } // 也有自己特有的方法 public void sing(){ System.out.println("鸟儿在歌唱!!!"); } } // 猫类,子类 public class Cat extends Animal{ // 对move方法进行重写 public void move(){ System.out.println("cat走猫步!"); } // 猫除了move之外,应该有自己特有的行为,例如抓老鼠。 // 这个行为是子类型对象特有的方法。 public void catchMouse(){ System.out.println("猫正在抓老鼠!!!!"); } } class Dog{ public void move(){ System.out.println("狗在散步"); } } ``` **编译阶段**: 编译器只知道a是Animal类型,所以在编译的时候,编译器会去Animal.class字节码文件去找move()方法,找到了的话,就绑定上move()方法,编译通过,静态绑定成功(编译阶段属于静态绑定) **运行阶段**: 运行阶段,实际上堆内存中创建的Java对象是Cat对象,所以运行的时候,真正参与move的对象是一只猫,所以运行阶段会动态执行Cat方法的move()方法,这个过程属于运行阶段绑定(运行阶段属于动态绑定) 总结来说就是:编译看左边,运行看右边 # 4. instanceof 关键字 4.1为什么要使用instanceof ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/dc97a6de2b3b4bd8a9663663b86ecf56.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASmF2YeiPnOm4n-eahOWtpuS5oOS5i-i3rw==,size_14,color_FFFFFF,t_70,g_se,x_16) ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/9d184b4f6ba844cebfb0b26d7cb7b104.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASmF2YeiPnOm4n-eahOWtpuS5oOS5i-i3rw==,size_13,color_FFFFFF,t_70,g_se,x_16) 4.2使用向下转型的危险 我们在向下转型的时候,最好使用instanceof关键字判断以后再转型,不然可能出现java.lang.ClassCastException异常 根据上面已经写的代码,我接下来,写一个例子,来说明一下 ```java Animal a = new Cat(); Bird b = (Bird) a; b.sing(); ``` 这个时候就会出现异常,虽然编译的时候不会报错,但是事实上,a引用底层其实是Cat,而b却指向了它,所以会报错,因为Cat里面没有sing方法
相关文章
|
7天前
|
安全 Java 数据库连接
Java中的异常处理机制及其最佳实践
【8月更文挑战第12天】在Java的世界里,异常处理是维护程序健壮性的关键环节之一。它不仅涉及到错误检测,还关乎如何优雅地恢复或报告错误。本文将深入探讨Java的异常处理机制,包括异常类型、捕获异常的策略以及异常的最佳处理实践。我们将一起学习如何通过有效的异常管理来提升代码质量和用户体验。
|
7天前
|
Java 数据库连接 开发者
Java中的异常处理机制深度解析
【8月更文挑战第13天】本文旨在深入探讨Java编程语言中一个至关重要的组成部分——异常处理机制。我们将从基本概念入手,逐步展开讨论异常处理在Java语言设计中的角色和重要性,以及如何正确利用这一机制来提高代码的健壮性和可维护性。文章将通过分析异常处理的最佳实践,揭示如何在复杂的应用程序中有效地管理和处理错误情况。
|
16天前
|
安全 Java 调度
解锁Java并发编程高阶技能:深入剖析无锁CAS机制、揭秘魔法类Unsafe、精通原子包Atomic,打造高效并发应用
【8月更文挑战第4天】在Java并发编程中,无锁编程以高性能和低延迟应对高并发挑战。核心在于无锁CAS(Compare-And-Swap)机制,它基于硬件支持,确保原子性更新;Unsafe类提供底层内存操作,实现CAS;原子包java.util.concurrent.atomic封装了CAS操作,简化并发编程。通过`AtomicInteger`示例,展现了线程安全的自增操作,突显了这些技术在构建高效并发程序中的关键作用。
42 1
|
16天前
|
存储 Oracle 安全
揭秘Java并发核心:深入Hotspot源码腹地,彻底剖析Synchronized关键字的锁机制与实现奥秘!
【8月更文挑战第4天】在Java并发世界里,`Synchronized`如同导航明灯,确保多线程环境下的代码安全执行。它通过修饰方法或代码块实现独占访问。在Hotspot JVM中,`Synchronized`依靠对象监视器(Object Monitor)机制实现,利用对象头的Mark Word管理锁状态。
27 1
|
3天前
|
存储 SQL 关系型数据库
深入MySQL锁机制:原理、死锁解决及Java防范技巧
深入MySQL锁机制:原理、死锁解决及Java防范技巧
|
6天前
|
Java 程序员 编译器
深入浅出Java异常处理机制
在Java编程的世界中,异常处理就像是我们生活中的急救包,它帮助我们处理程序运行时出现的意外情况。本文将带你了解Java异常处理的基础知识,探索异常类型,学习如何捕获和处理它们,并讨论最佳实践。让我们一起走进Java异常处理的世界,学会如何使用这个强大的工具来保护我们的程序。
|
7天前
|
安全 Java 程序员
Java中的异常处理机制:从基础到高级
【8月更文挑战第13天】在Java编程中,异常处理是一个不可或缺的部分。本文将深入探讨Java的异常处理机制,从基本概念出发,逐步解析try-catch-finally语句块的使用,探讨自定义异常类的设计,以及介绍高级异常处理技术如try-with-resources和异常链。通过这些内容的学习,读者将能够更加有效地管理和控制程序运行时的错误。
|
7天前
|
Java
Java 新手入门:Java 封装、继承、多态详解
Java 新手入门:Java 封装、继承、多态详解
16 1
|
9天前
|
消息中间件 负载均衡 Java
"深入Kafka核心:探索高效灵活的Consumer机制,以Java示例展示数据流的优雅消费之道"
【8月更文挑战第10天】在大数据领域,Apache Kafka凭借其出色的性能成为消息传递与流处理的首选工具。Kafka Consumer作为关键组件,负责优雅地从集群中提取并处理数据。它支持消息的负载均衡与容错,通过Consumer Group实现消息的水平扩展。下面通过一个Java示例展示如何启动Consumer并消费数据,同时体现了Kafka Consumer设计的灵活性与高效性,使其成为复杂消费场景的理想选择。
37 4
|
9天前
|
消息中间件 负载均衡 Java
"Kafka核心机制揭秘:深入探索Producer的高效数据发布策略与Java实战应用"
【8月更文挑战第10天】Apache Kafka作为顶级分布式流处理平台,其Producer组件是数据高效发布的引擎。Producer遵循高吞吐、低延迟等设计原则,采用分批发送、异步处理及数据压缩等技术提升性能。它支持按消息键值分区,确保数据有序并实现负载均衡;提供多种确认机制保证可靠性;具备失败重试功能确保消息最终送达。Java示例展示了基本配置与消息发送流程,体现了Producer的强大与灵活性。
28 3