50 lines
2.0 KiB
Java
50 lines
2.0 KiB
Java
package com.example.scaffold.learning.lifecycle;
|
||
|
||
import jakarta.annotation.PostConstruct;
|
||
import jakarta.annotation.PreDestroy;
|
||
import org.springframework.stereotype.Component;
|
||
|
||
import java.util.LinkedHashMap;
|
||
import java.util.Map;
|
||
import java.util.UUID;
|
||
import java.util.concurrent.atomic.AtomicInteger;
|
||
|
||
@Component("iocSingletonLifecycleBean")
|
||
public class SingletonLifecycleBean implements LifecycleDemoBean {
|
||
|
||
static {
|
||
IocLifecycleTracker.record("iocSingletonLifecycleBean", "singleton", "class-load", "JVM 初始化类(static block)");
|
||
}
|
||
|
||
private final String instanceId = UUID.randomUUID().toString().substring(0, 8);
|
||
private final AtomicInteger accessCount = new AtomicInteger(0);
|
||
|
||
public SingletonLifecycleBean() {
|
||
IocLifecycleTracker.record("iocSingletonLifecycleBean", "singleton", "constructor", "构造器执行,实例ID=" + instanceId);
|
||
}
|
||
|
||
@PostConstruct
|
||
public void init() {
|
||
IocLifecycleTracker.record("iocSingletonLifecycleBean", "singleton", "post-construct", "Bean 初始化完成,已进入单例生命周期");
|
||
}
|
||
|
||
@PreDestroy
|
||
public void destroy() {
|
||
IocLifecycleTracker.record("iocSingletonLifecycleBean", "singleton", "pre-destroy", "容器关闭时销毁单例 Bean");
|
||
}
|
||
|
||
@Override
|
||
public Map<String, Object> inspect(String trigger) {
|
||
int count = accessCount.incrementAndGet();
|
||
IocLifecycleTracker.record("iocSingletonLifecycleBean", "singleton", "method-call", "trigger=" + trigger + ", accessCount=" + count);
|
||
Map<String, Object> result = new LinkedHashMap<>();
|
||
result.put("beanName", "iocSingletonLifecycleBean");
|
||
result.put("scope", "singleton");
|
||
result.put("instanceId", instanceId);
|
||
result.put("identityHashCode", System.identityHashCode(this));
|
||
result.put("accessCount", count);
|
||
result.put("explanation", "单例 Bean 在容器中通常只创建一次,后续每次获取都是同一个实例");
|
||
return result;
|
||
}
|
||
}
|