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;
}
相关推荐
华科大胡子3 分钟前
AI开发者的网络卡点:Anthropic连接超时
开发语言·php
_Aaron___16 分钟前
Spring AI 接入 MCP:工具调用不是“能调就行”,关键是边界治理
java·人工智能·spring
磊 子26 分钟前
STL无序关联容器—unorded_set+unorded_map
开发语言·c++
向量引擎31 分钟前
从零起步,如何打造专属向量引擎 API 中转工作流?
java·服务器·前端
LJianK131 分钟前
普通接口,用到getter和setter方法的地方,jackson转换
java
辰海Coding35 分钟前
MiniSpring框架学习-分解 Dispatcher
java·学习·spring·架构
AI人工智能+电脑小能手38 分钟前
【大白话说Java面试题 第84题】【Mysql篇】第14题:为什么用 InnoDB 存储引擎的表建议用整型的自增主键?
java·开发语言·数据库·mysql·面试
小江的记录本1 小时前
【JVM虚拟机】JVM调优:常用JVM参数、调优核心指标、OOM排查、GC日志分析、Arthas工具使用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
金銀銅鐵1 小时前
[Java] 用图形化界面演示 iadd, isub, iconst_<i> 指令的效果
java·后端·python
J2虾虾1 小时前
Spring AI Alibaba文档
java·人工智能·spring