springboot项目后的入口类
创建springboot项目之后,在项目中有一个*Application的类,该类即为该项目的入口类,该类中存在一个main函数,即为java应用的入口方法,如下:
@SpringBootApplication
public class *Application {
public static void main(String[] args) {
SpringApplication app = new SpringApplication(*Application.class);
app.run(args);
}
}
在此方法中使用application.run启动springboot项目。
@SpringBootApplication是干嘛用的呢?
@springbootApplication说明
该注解是一个组合注解,且看源码如下:
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
excludeFilters = {@Filter(
type = FilterType.CUSTOM,
classes = {TypeExcludeFilter.class}
), @Filter(
type = FilterType.CUSTOM,
classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {
@AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "exclude"
)
Class<?>[] exclude() default {};
@AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "excludeName"
)
String[] excludeName() default {};
@AliasFor(
annotation = ComponentScan.class,
attribute = "basePackages"
)
String[] scanBasePackages() default {};
@AliasFor(
annotation = ComponentScan.class,
attribute = "basePackageClasses"
)
Class<?>[] scanBasePackageClasses() default {};
}
源码说明:
-
@Target({ElementType.TYPE})–>接口或者枚举
-
@Retention(RetentionPolicy.RUNTIME)–>运行级别保留,编译后的class文件中存在,在jvm运行时保留,可以被反射调用
-
@Documented -->指明修饰的注解,可以被例如javadoc此类的工具文档化,只负责标记,没有成员取值
-
@Inherited–>允许子类继承父类中的注解
注:由此可见@SpringbootApplication主要组合了@SpringBootConfiguration、@EnableAutoConfiguration、@ComponentScan三个注解。如果不使用@SpringbootApplication那么我们可以直接使用这三个注解代替。 -
@SpringBootConfiguration–>继承于@Configuration,二者功能也一致,标注当前类是配置类,并会将当前类内声明的一个或多个以@Bean注解标记的方法的实例纳入到spring容器中,并且实例名就是方法名。
-@EnableAutoConfiguration–>启用 Spring 应用程序上下文的自动配置,尝试猜测并配置您可能需要的bean。自动配置类通常根据您的 classpath 和您已经定义的bean来实现。
-@ComponentScan–>根据定义的扫描路径,把符合扫描规则的类装配到spring容器中