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;
}
相关推荐
xiaoshuaishuai813 分钟前
C# 实现百度搜索算法逆向
开发语言·windows·c#·dubbo
A-Jie-Y13 分钟前
JAVA框架-SpringBoot环境搭建指南
java·spring boot
yuan1999715 分钟前
使用模糊逻辑算法进行路径规划(MATLAB实现)
开发语言·算法·matlab
深兰科技21 分钟前
深兰科技与淡水河谷合作推进:矿区示范加速落地
java·人工智能·python·c#·scala·symfony·深兰科技
码界奇点34 分钟前
基于Spring Boot的前后端分离商城系统设计与实现
java·spring boot·后端·java-ee·毕业设计·源代码管理
一叶飘零_sweeeet36 分钟前
深度剖析:Java 并发三大量难题 —— 死锁、活锁、饥饿全解
java·死锁·活锁·饥饿
蒸汽求职40 分钟前
北美求职身份过渡:Day 1 CPT 的合规红线与安全入职指南
开发语言·人工智能·安全·pdf·github·开源协议
IT乐手42 分钟前
java 对比分析对象是否有变化
android·java
云烟成雨TD1 小时前
Spring AI Alibaba 1.x 系列【18】Hook 接口和四大抽象类
java·人工智能·spring
Hachi被抢先注册了1 小时前
Docker学习记录
java·云原生·eureka