Java学习笔记(对象)

一、对象本质

状态(State):通过成员变量(Field)描述

行为(Behavior):通过成员方法(Method)实现

java 复制代码
class Person {
    String name;
    int age;
    void eat() {
        System.out.println(name + "正在吃饭");
    }
}

对象的三大特性:​

  1. 封装性:将数据和操作封装成独立单元
  1. 继承性:通过extends实现代码复用
  1. 多态性:父类引用指向子类对象的动态特性

二、对象生命周期

(一)对象创建的四个阶段

类加载检查:JVM 检查是否已加载该类的字节码​

内存分配:在堆内存中划分存储区域(TLAB 优化机制)​

初始化零值:基本类型赋默认值(int=0,boolean=false)​

执行初始化:构造方法执行前的显式初始化

java 复制代码
Person person = new Person(); 

(二)内存存储结构

|-----|------------|------------|
| 区域 | 存储内容 | 特点 |
| 栈内存 | 引用变量 | 线程私有,自动释放 |
| 堆内存 | 对象实例 | 线程共享,GC 管理 |
| 方法区 | 类信息 / 静态变量 | 共享,存储元数据 |

(三)对象销毁机制

引用计数法:循环引用问题无法解决​

可达性分析:通过 GC Roots 标记可回收对象​

finalize () 方法:对象销毁前的最后回调机会

三、核心应用

(一)构造方法的深度运用

java 复制代码
class Student {
    private String name;
    private int age;
    public Student() {}
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
    public Student(String name) {
        this(name, 18);
    }
}

(二)对象比较的正确姿势

== 运算符:比较引用地址(基本类型比较值)​

equals () 方法:建议重写实现内容比较​

hashCode () 契约:重写 equals 必须重写 hashCode

java 复制代码
@Override
public boolean equals(Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;
    Student student = (Student) o;
    return age == student.age && Objects.equals(name, student.name);
}

@Override
public int hashCode() {
    return Objects.hash(name, age);
}

(三)对象克隆的实现方式

浅克隆:实现 Cloneable 接口,重写 clone ()​

深克隆:通过序列化 / 反序列化实现对象复制

java 复制代码
class ShallowClone implements Cloneable {
    int[] array = new int[5];
    @Override
    protected Object clone() throws CloneNotSupportedException {
        return super.clone();
    }
}

四、高级特性

(一)反射机制操作对象

java 复制代码
Class<?> clazz = Class.forName("com.example.Person");
Person person = (Person) clazz.getDeclaredConstructor().newInstance();
Method method = clazz.getDeclaredMethod("privateMethod");
method.setAccessible(true);
method.invoke(person);

(二)代理模式增强对象

java 复制代码
InvocationHandler handler = (proxy, method, args) -> {
    System.out.println("前置处理");
    Object result = method.invoke(target, args);
    System.out.println("后置处理");
    return result;
};
Service proxy = (Service) Proxy.newProxyInstance(
    ClassLoader.getSystemClassLoader(),
    new Class[]{Service.class},
    handler
);

(三)对象序列化规范

java 复制代码
class SerializableObject implements Serializable {
    private static final long serialVersionUID = 1L;
    transient String sensitiveInfo;
}
相关推荐
程序猿大帅4 小时前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪5 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly5 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
众少成多积小致巨6 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
东坡白菜6 小时前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
SimonKing12 小时前
艹,维护AI写的代码,我心态崩了......
java·后端·程序员
用户2986985301413 小时前
Java Word 文档样式进阶:段落与文本背景色设置完全指南
java·后端
小bo波1 天前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
nanxun8862 天前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103512 天前
Day01 | Java 基础(Java SE)
java