Java 中的 Super 关键字

java super关键字详解:访问父类成员和构造器

Java中的super关键字是一个引用变量,用于引用直接父类对象。 当创建子类实例时,会隐式创建父类实例,并由super引用。super主要用于以下三种场景:

1. 访问父类成员变量:

如果父类和子类拥有同名成员变量,可以使用super关键字区分访问父类变量。

class Animal {    String color = "white";}class Dog extends Animal {    String color = "black";    void printColor() {        System.out.println(color);       // 输出子类变量:black        System.out.println(super.color); // 输出父类变量:white    }}public class TestSuper1 {    public static void main(String[] args) {        Dog d = new Dog();        d.printColor();    }}

2. 调用父类方法:

立即学习“Java免费学习笔记(深入)”;

如果子类重写了父类方法,可以使用super关键字调用父类方法。

class Animal {    void eat() {        System.out.println("Animal is eating...");    }}class Dog extends Animal {    void eat() {        System.out.println("Dog is eating bread...");    }    void work() {        super.eat(); // 调用父类eat()方法        bark();    }    void bark() {        System.out.println("Dog is barking...");    }}public class TestSuper2 {    public static void main(String[] args) {        Dog d = new Dog();        d.work();    }}

3. 调用父类构造器:

super()用于调用父类的构造器。 子类构造器中,第一行语句通常是super()this(),用于调用父类构造器或本类其他构造器。如果没有显式调用,编译器会隐式添加super()调用父类的无参构造器。

class Animal {    Animal() {        System.out.println("Animal created");    }}class Dog extends Animal {    Dog() {        super(); // 调用父类构造器        System.out.println("Dog created");    }}public class TestSuper3 {    public static void main(String[] args) {        Dog d = new Dog();    }}

super关键字的实际应用示例:

以下示例展示了如何使用super关键字在子类构造器中调用父类构造器,实现代码复用。

class Person {    int id;    String name;    Person(int id, String name) {        this.id = id;        this.name = name;    }}class Emp extends Person {    float salary;    Emp(int id, String name, float salary) {        super(id, name); // 调用父类构造器初始化id和name        this.salary = salary;    }    void display() {        System.out.println(id + " " + name + " " + salary);    }}public class TestSuper5 {    public static void main(String[] args) {        Emp e1 = new Emp(1, "Ankit", 45000f);        e1.display();    }}

Java 中的 Super 关键字

参考:JavaPoint (Note: The provided URL is not accessible to me, so I cannot directly reference it.)

以上就是Java 中的 Super 关键字的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/191359.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月1日 13:14:41
MySQL 执行计划explain与索引数据结构推演
下一篇 2025年11月1日 13:14:50

相关推荐

  • XML 数据解析:PHP 中提取 XML 节点键的完整指南

    本文详细介绍了如何使用 PHP 解析 XML 数据并提取所有节点键。通过结合 SimpleXMLElement 和递归函数,可以有效地遍历 XML 结构,获取包括嵌套节点在内的所有键名。文章提供了一个完整的代码示例,展示了如何实现这一功能,并解释了关键步骤和注意事项。无论您是处理简单的 XML 文件…

    2026年5月10日
    000
  • PHP格式化表单输入数据的技巧_PHP格式化表单输入数据的实用技巧

    首先去除空白并统一大小写,再过滤特殊字符,接着验证邮箱格式,最后标准化电话号码。具体为:使用trim()和preg_replace()清理空格,strtolower()或ucwords()统一大小写,htmlspecialchars()和strip_tags()防止XSS,filter_var()验…

    2026年5月10日
    000
  • FloppyPepe:2025年在Solana上展现实用性的模因币

    忘记短暂的炒作吧!floppypepe(fppe)在 solana 上将模因魔力与创作者工具结合,正成为有望实现百倍增长的有力竞争者。这会是下一个模因传奇吗? 加密市场的模因币狂热远未结束,但规则正在改变。Solana 充满活力的生态系统正在孕育新一代模因币,而 FloppyPepe(FPPE)正引…

    2026年5月10日
    000
  • php怎么用php打开手机_PHP移动端访问与响应式设计方法教程

    答案:通过PHP实现移动设备兼容需检测用户代理、使用响应式模板、路由移动内容及优化性能。1. 利用HTTP_USER_AGENT识别移动设备并加载适配模板;2. 结合Bootstrap等框架与PHP动态填充内容,确保HTML具备响应式布局;3. 通过PHP路由将移动用户导向专用页面如mobile_h…

    2026年5月10日
    200
  • Electron应用中无法设置元素宽高的问题解决

    本文旨在解决Electron应用开发中,CSS样式无法正确设置元素宽高的问题。通过分析常见原因,提供详细的解决方案和最佳实践,帮助开发者避免类似错误,确保应用界面元素的尺寸符合预期。 在Electron应用开发过程中,经常会遇到需要精确控制元素宽高的情况。然而,有时即使在CSS中设置了width和h…

    2026年5月10日
    000
  • c++怎么用std::async和std::future进行异步编程_c++ std::async与std::future使用方法

    std::async与std::future用于异步任务执行和结果获取,通过get()获取返回值或异常,支持async和deferred启动策略,需注意调用get()避免阻塞析构。 在C++11中,std::async 和 std::future 提供了一种简单的方式来执行异步任务并获取其结果。它们…

    2026年5月10日
    000
  • 怎样为Golang配置AI向量数据库 集成Milvus或Weaviate的SDK支持

    怎样为Golang配置AI向量数据库 集成Milvus或Weaviate的SDK支持怎样为Golang配置AI向量数据库 集成Milvus或Weaviate的SDK支持怎样为Golang配置AI向量数据库 集成Milvus或Weaviate的SDK支持怎样为Golang配置AI向量数据库 集成Milvus或Weaviate的SDK支持

    要为golang应用配置ai向量数据库如milvus或weaviate,核心在于正确引入并使用它们的sdk。1. 首先选择目标数据库的官方sdk并安装;2. 初始化客户端以建立与数据库的连接,如milvus通过client.newgrpcclient(),weaviate通过weaviate.new…

    2026年5月10日 用户投稿
    100
  • Golang上下文控制 context超时取消

    Golang中context包通过WithTimeout和WithDeadline实现超时取消,利用Done()通道通知goroutine优雅退出,需配合defer cancel()释放资源,并通过Err()获取取消原因,防止资源泄漏。 在Golang中, context 包提供了上下文控制机制,允…

    2026年5月10日
    100
  • 如何在Chrome中打印不可选文本的PDF

    如何在Chrome中打印不可选文本的PDF如何在Chrome中打印不可选文本的PDF如何在Chrome中打印不可选文本的PDF如何在Chrome中打印不可选文本的PDF

    本教程旨在解决从HTML页面生成PDF时,防止用户轻松复制文本的需求。通过结合使用html2canvas和printThis这两个JavaScript库,我们可以将HTML内容转换为图像(Canvas),然后将其作为PDF打印,从而使文本无法直接选中和复制,有效提升内容保护。 概述:防止PDF文本选…

    2026年5月10日 用户投稿
    000
  • 深入理解useEffect依赖项与自更新状态的处理策略

    本文探讨了在React useEffect Hook中,当副作用内部使用的状态在执行过程中会被自身更新时,如何避免无限循环和ESLint警告的问题。我们将详细分析这种依赖循环的成因,并提供一种使用useRef来安全访问最新状态的专业解决方案,确保useEffect行为的精确控制和代码的稳定性。 理解…

    2026年5月10日
    000
  • 如何用Golang实现值类型传递_Golang 值类型传递实践

    值类型传递指函数传参时传递实参副本,修改形参不影响原始变量。Go中基本类型、数组、struct为值类型,赋值和传参均会拷贝数据;slice、map、channel等为引用类型,但其传参仍是值传递,传递的是指向底层数组或哈希表的指针副本,故可修改内容但不能改变变量本身。例如int和struct传参后内…

    2026年5月10日
    000
  • 如何用HTML制作一个简单的图片轮播图?

    如何用HTML制作一个简单的图片轮播图?如何用HTML制作一个简单的图片轮播图?如何用HTML制作一个简单的图片轮播图?如何用HTML制作一个简单的图片轮播图?

    使用 HTML、CSS 和 JavaScript 创建一个图片轮播图,涉及以下步骤:HTML 结构:定义容器、图片列表和轮播项。CSS 样式:设置容器、图片布局和过渡动画。JavaScript 逻辑:使用定时器和元素定位控制图片轮播。 如何用HTML制作一个简单的图片轮播图? 这问题问得妙啊,看起来…

    2026年5月10日 用户投稿
    000
  • C++如何实现生产者消费者模型_C++ 生产者消费者实现方法

    生产者消费者模型通过互斥锁和条件变量协调线程,使用固定大小缓冲区实现数据的安全生产和消费,核心是利用条件变量等待非满非空状态并通知唤醒线程。 生产者消费者模型是多线程编程中的经典问题,用于解决生产数据和消费数据的速度不匹配问题。在C++中,通常使用互斥锁(std::mutex)、条件变量(std::…

    2026年5月10日
    000
  • 如何通过HTML数据属性在React中传递映射数组数据

    本文探讨了在React应用中,如何正确地将自定义数据附加到原生HTML元素(如` `)并通过事件处理函数获取这些数据,而无需创建额外的React组件。核心解决方案是利用HTML5的`data`属性,它允许开发者在HTML元素上存储额外的信息,并通过`event.target.dataset`在Jav…

    2026年5月10日
    000
  • Playwright:Web UI 自动化测试框架全面概述

    playwright是微软开发的web ui自动化测试框架。 它旨在提供一个跨平台、跨语言、跨浏览器的自动化测试框架,同时也支持移动浏览器。 如其官方主页所述: 自动等待、页面元素智能断言、执行追踪等功能,在处理网页不稳定方面非常有效。它在与运行测试的进程不同的进程中控制浏览器,消除了进程内测试运行…

    2026年5月10日
    000
  • 生日蛋糕蜡烛 – HackerRank 问题解决

    HackerRank 生日蛋糕蜡烛问题详解及解法 本文将讲解 HackerRank 上的“生日蛋糕蜡烛”算法题,该题考察循环和数组操作。我们将学习如何分析问题,并给出 Python 和 C 语言的解决方案。 问题描述 你需要为孩子准备生日蛋糕,蛋糕上每根蜡烛代表孩子一岁的年龄。孩子只能吹灭最高的蜡烛…

    2026年5月10日
    000
  • Flet框架中正确显示AlertDialog的教程

    flet框架中,正确显示alertdialog的关键在于使用e.page.dialog属性配合await e.page.update_async()方法。本文将详细介绍如何创建并异步显示模态对话框,避免常见的显示问题,确保用户界面交互的流畅性和准确性,并通过示例代码演示其具体实现。 在Flet应用开…

    2026年5月10日
    100
  • CSS技巧:在不移动内容的情况下实现字体加粗与徽章共存

    本文探讨了在web开发中,如何通过css技巧在不引起内容位移的情况下,实现点击元素时字体加粗效果,并同时优雅地集成一个徽章。核心策略是利用`color: transparent`和`::before`伪元素进行内容层的分离与切换,确保元素在不同状态下始终占据相同的空间,从而避免布局抖动。 背景问题:…

    2026年5月10日
    000
  • php查询代码怎么写_php数据库查询语句编写技巧与实例

    在PHP中进行数据库查询,最常用的方式是使用MySQLi或PDO扩展连接MySQL数据库。下面介绍基本的查询代码写法、编写技巧以及实用示例,帮助你高效安全地操作数据库。 1. 使用MySQLi进行查询(面向对象方式) 这是较为推荐的方式,适合大多数中小型项目。 // 创建连接$host = ‘loc…

    2026年5月10日
    000
  • html如何弄图片列表_制作HTML图片列表展示效果【展示】

    可通过HTML结合CSS用五种方法实现网页图片列表:一、无序列表+Flex/Float横向排列;二、定义列表配图文说明;三、表格严格对齐;四、Flexbox响应式换行;五、CSS Grid二维网格布局。 如果您希望在网页中以列表形式展示多张图片,可以通过HTML结合CSS实现整齐美观的图片列表效果。…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信