如果一个类A实现Lifecycle接口,那么需要注意
1.A可以是任意一个容器中的Bean,A也可以是容器
2.当容器调用start或者close方法的时候,会根据A中的isRunning方法判断是否调用A中的start或者stop方法(回调)

下面定义一个A

@Component
public class MyLifeCycleBean1 implements Lifecycle {
@Override
public void start() {
System.out.println("start1");
}
@Override
public boolean isRunning() {
System.out.println("isRunning1");
return false;
}
@Override
public void stop() {
System.out.println("stop1");
}
}

简单阐述一下这个类的三个方法
start:如果类A没运行,则走该方法,如果类A已经运行,则不会走该方法
isRunning:返回true表示类A已经运行,返回false表示类A没运行
stop:如果类A正在运行,则走该方法,如果类A已经停止,则不走该方法
main方法1

public static void main(String[] args) {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(
"MyLifeCycleBean1所在包");
ctx.start();
ctx.close();
}

该方法会打印出

isRunning1
start1
isRunning1

当调用ctx的start方法的时候,ctx会先调用一下isRunning方法,由于isRunning方法一直返回false,ctx认为类A没有运行,所以ctx会调用start方法,表示让类A运行起来
当调用ctx的close方法的时候,同上,ctx会也会先调用一下isRunning方法,由于isRunning方法一直返回false,所以ctx认为类A压根就没有运行(停止状态),那么ctx就没必要再调用stop方法,所以没有打印出"stop1"