当前位置: 代码网 > it编程>编程语言>Java > Java super、this、static关键字实践案例

Java super、this、static关键字实践案例

2025年11月03日 Java 我要评论
一.java继承(1)继承继承的本质就是代码的复用,子类继承父类的全局变量和方法(public,protected)public class animal{ public string name

一.java继承

(1)继承

继承的本质就是代码的复用,子类继承父类的全局变量和方法(public,protected)

public class animal{
    public string name;
    public string color;
    public void run(){
    }
    public void eat(){
    }
    //....
}
public class dog extends animal{
    public string name;
    public string color;
    public void run(){
    }
    public void eat(){
    }
    //....
}
public class cat extends animal{
    public string name;
    public string color;
    public void run(){
    }
    public void eat(){
    }
    //....
}
  • 父类 animal:定义了公共的成员变量namecolor,以及公共方法run()eat(),这些是动物类的通用属性和行为。
  • 子类 dog 和 cat:通过extends关键字继承animal类,从而拥有了父类的namecolorrun()eat()。

(2)继承父类并创建对象在内存当做发生什么

创建子类的时候一定会去创建父类对象---->先创建父类对象,在创建子类对象

  • 当创建子类对象(如catdog)时,会先创建父类animal的对象(堆中0x1标识的区域,包含父类的namecolorrun()eat()),再基于父类对象创建子类对象(如cat 0x2对应的堆区域,继承父类的结构后,还会添加子类自身的特性)。

  • 父类 animal:包含构造方法 public animal(){ system.out.println("我是animal"); },当父类对象被创建时,该构造方法会执行,打印 “我是 animal”。
  • 子类 cat:继承自 animal,其构造方法 public cat(){ system.out.println("我是cat"); } 会在父类构造方法执行后执行,打印 “我是 cat”。
  • 测试类 test:在 main 方法中创建 cat 对象 cat cat = new cat();,触发构造方法的执行链。

(3)java程序为什么new 子类对象时,结果先创建父类对象在创建子类对象

原因在于有方法重写

*****方法重写和方法重载的区分

1)方法重写:父类的方法被子类重写(父类当中的方法不应完全适用于子类)

  • 左侧 “cat 0x1” 代表子类 cat 的对象(0x1 是对象在内存中的标识)。
  • 上方区域包含run()eat()方法和name=nullcolor=null属性,代表父类的成员(方法和属性)
  • 下方区域的run()方法(浅蓝色)代表子类 cat 对父类 run () 方法的重写—— 子类通过重写,让run()方法的行为更贴合 “猫” 的特性,而父类的eat()方法等未被重写时,子类会继承使用

2)方法重载:发生在同一个类当中,方法名称相同,参数列表不同的方法,叫做方法

java程序是通过方法的签名来验证这是不是一个方法(方法签名:方法名+参数列表(数据类型)

public class cat extends animal {
    public void run() {
        system.out.println("迈开四只脚跑……");
    }
    public void jump(){
        system.out.println("跳起来了……");
    }
    public void jump(int a){
        system.out.println("跳起来了……");
    }
    public void jump(string name){
    }
}

cat类中,jump方法出现了多次:

  • public void jump(){...}(无参数)
  • public void jump(int a){...}(参数为int类型)
  • public void jump(string name){...}(参数为string类型)这几个方法名称相同,但参数列表不同,属于方法重载的典型案例;而run方法只有一个定义,不涉及重载。

(4)java继承层次--------->java只支持单继承

一个子类只能有一个父类,一个父类可以有多个父类

是用来防止因多继承带来的复杂逻辑和内存管理问题

  • animal是顶层父类,catdog都直接继承自animal(体现 “一个父类可以有多个子类”)。
  • dog作为父类,又有小黑狗类小黄狗类小白狗类三个子类。
  • 图中 “不允许” 的箭头表示:小黑狗类不能同时继承catdog,因为 java 不支持多继承(一个子类只能有一个直接父类)。

二.super关键字

super代表父类,调用父类当中的方法和变量

public void jump(int a) {
    super.color = "黑色";
    super.run();
    super.eat();
    system.out.println("猫跳高了......");
}

jump(int a)方法中:

  • super.color = "黑色";:调用并设置父类的成员变量color的值为 “黑色”。
  • super.run();super.eat();:调用父类的run()方法和eat()方法。
  • 最后执行子类自身的逻辑system.out.println("猫跳高了……");

三.this关键字------------>this代表当前对象

(1)this属性名称

java中为解决变量的名称冲突和不确定性问题,引入关键字this代表其所在方法的当前对象的引用。

(2)this:方法名

代表当前的对象调用某一方法。

(3)注意

1)不能在普通方法当前中只能在构造方法中使用。

2)在构造方法当中必须是第一条语句。

3)不能和super()一起使用。

四.static关键字

(1)static的 “归属” 本质

static 修饰的元素属于 “类”,而非类的 “对象(实例)”。

示例:.java 源文件(如 hello.java)编译为 .class 字节码后,static 成员随类加载到方法区,不依赖对象存在。

(2)static的内存模型(jvm 视角)

jvm 内存分为虚拟机栈、堆、方法区static 成员的存储规则如下:

  • 静态变量 / 方法 / 代码块:存储在方法区的 “类信息” 区域,属于类的共享资源。
  • 非静态方法:也存储在方法区,但属于 “对象可调用” 的成员(需通过对象触发)。
  • 堆内存:仅存储对象的实例数据,static 成员不在这里。
  • 虚拟机栈:存储方法调用的栈帧,执行 mainrun 等方法时的局部变量在此分配。
public class testconfigparser {
    public static void main(string[] args) {
        eat();
        new testconfigparser().run();
    }
    public void run(){}
    public static void eat(){}
}

(3) 静态方法(类方法)

  • 访问方式
    • 推荐:类名.方法名()(如 testconfigparser.eat());
    • 不推荐:对象.方法名()(易混淆,不体现 “类归属” 本质)。
  • 调用限制
    • 静态方法中不能直接调用非静态方法(非静态方法属于 “对象”,静态方法加载时可能还没有对象);
    • 非静态方法中可以调用静态方法(对象存在时,类一定已加载);
    • 静态方法中不能使用 this 关键字this 代表 “当前对象”,静态方法不依赖对象)。
public class testconfigparser {
    public static void main(string[] args) {
        new testconfigparser().run(); // 非静态方法需通过对象调用
    }
    public void run(){} // 非静态方法
    public static void eat(){} // 静态方法
}

(4)静态代码块

  • 执行时机:在 main 方法之前执行,且仅执行一次(类加载时执行)。
  • 作用:用于初始化静态变量、加载资源(如配置文件、数据库驱动)等 “类级别的初始化操作”。
public static void main(string[] args) {
    demo demo = new demo();
    demo demo1 = new demo();
    demo demo2 = new demo();
    demo.from = "中国"; // 修改静态变量
    system.out.println(demo.from);   // 输出“中国”
    system.out.println(demo1.from);  // 输出“中国”
    system.out.println(demo2.from);  // 输出“中国”
}

(5)static的加载顺序

  • 规则:static修饰的代码块 在main方法之前执行,先加载父类,在加载子类,创建子类对象之前先创建父类对象
  • 示例代码(体现父子类静态加载顺序):
public class test extends base {
    static {
        system.out.println("test static");
    }
    public test() {
        system.out.println("test constructor");
    }
    public static void main(string[] args) {
        new test();
    }
}
class base {
    static {
        system.out.println("base static");
    }
    public base() {
        system.out.println("base constructor");
    }
}
// 执行结果:
// base static
// test static
// base constructor
// test constructor
class demo {
    public demo(string aa) {
        system.out.println("=====" + aa);
    }
    static {
        system.out.println("11");
    }
    public static demo demo = new demo("+++");
    static {
        system.out.println("22");
    }
}
class test {
    public static void main(string[] args) {
        demo demo = new demo("----");
    }
}
//11
//=====+++
//22
//=====----

到此这篇关于java super、this、static关键字的文章就介绍到这了,更多相关java super this static关键字内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

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

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com