纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

@Component注解含义 关于@Component注解的含义说明

Thinkingcao   2021-11-18 我要评论
想了解关于@Component注解的含义说明的相关内容吗Thinkingcao在本文为您仔细讲解@Component注解含义的相关知识和一些Code实例欢迎阅读和指正我们先划重点:@Component注解,@Component注解下面大家一起来学习吧。

一、注解分类

1、@controller:controller控制器层(注入服务)

2、@service:service服务层(注入dao)

3、@repository:dao持久层(实现dao访问)

4、@component:标注一个类为Spring容器的Bean(把普通pojo实例化到spring容器中相当于配置文件中的<bean id="" class=""/>)

二、@Component 注解含义

@Component: 标注Spring管理的Bean使用@Component注解在一个类上表示将此类标记为Spring容器中的一个Bean。

三、基于@Component扩展的注解

@Repository

@Repository本身是基于@Component注解的扩展被@Repository注解的POJO类表示DAO层实现从而见到该注解就想到DAO层实现使用方式和@Component相同;

@Service

@Service本身是基于@Component注解的扩展被@Service注解的POJO类表示Service层实现从而见到该注解就想到Service层实现使用方式和@Component相同;

@Controller

@Controller本身是基于@Component注解的扩展被@Controller注解的类表示Web层实现从而见到该注解就想到Web层实现使用方式和@Component相同;

Tips:使用@Component@Service@Controller@Repository注解的类表示把这些类纳入到spring容器中进行管理同时也是表明把该类标记为Spring容器中的一个Bean。

四、component的扫描组件

下面写这行配置是引入component的扫描组件

<context:component-scan base-package=”com.mmnc”> 

其中base-package为指定需要扫描的包(含所有子包) 扫描被@Service、@Controller、@Repository、@Component等注解标注的Java类将其扫描注入到Spring容器注入成Bean:

  • @Service用于标注业务层组件
  • @Controller用于标注控制层组件(如struts中的action)
  • @Repository用于标注数据访问组件即DAO组件.
  • @Component泛指组件当组件不好归类的时候我们可以使用这个注解进行标注标识为一个Bean。

五、方法初始化和销毁

从Java EE5规范开始Servlet增加了两个影响Servlet生命周期的注解: @PostConstruct和@PreConstruct 这两个注解被用来修饰一个非静态的void()方法而且这个方法不能有抛出异常声明标注方法的初始化和销毁当你需要在系统启动时提前设置一下变量或者设置值操作时可以使用@PostConstruct注解进行项目启动时设置来完成当你需要处理关闭资源或者发送通知相关操作时可以使用@PreConstruct 完成。

1. @PostConstruct注解

被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行并且只会被服务器调用一次类似于Servlet的inti()方法。被@PostConstruct修饰的方法会在构造函数之后init()方法之前运行。

2. @PreDestroy注解

被@PreDestroy修饰的方法会在服务器卸载Servlet的时候运行并且只会被服务器调用一次类似于Servlet的destroy()方法。被@PreDestroy修饰的方法会在destroy()方法之后运行在Servlet被彻底卸载之前。

加载顺序如图:

在Spring中可以使用以下方式指定初始化方法和销毁方法(方法名任意):

//对象创建并赋值之后调用
@PostConstruct
public void init() { 
  System.out.println("对象创建并赋值之后调用...");
} 

//容器移除对象之前
@PreDestroy
public void detory(){
 System.out.println("容器移除对象之前执行...");
}

3. 示例

@Controller
@Lazy(false)
public class ServletInit { 
 @Autowired
 private PCASigninServlet  pcaSigninServlet;
 @Autowired
 private PCASignoutServlet pcaSignoutServlet;
 @Autowired
 private PCAInitServlet pcaInitServlet;
 @Autowired
 private PCALogoutServlet pcaLogoutServlet;
 @Autowired
 private PCAInfoServlet pcaInfoServlet;
 @Autowired
 private HelloServlet helloServlet; 
 @Autowired @Qualifier("handler")
 private WebAppContext webapp; 
 
 @PostConstruct
 void init(){
      Server server = new Server(8848);
         ServletContextHandler contextHander = new ServletContextHandler(ServletContextHandler.SESSIONS);  
         contextHander.setContextPath("/");  
         System.out.println("start init");
         HandlerCollection hc =new HandlerCollection();  
         hc.setHandlers(new Handler[]{webapp, contextHander});
         server.setHandler(hc);  
         System.out.println("addServlet /hello");
         contextHander.addServlet(new ServletHolder(helloServlet), "/hello");
         contextHander.addServlet(new ServletHolder( pcaSigninServlet), "/pca/signin");  
            contextHander.addServlet(new ServletHolder( pcaSignoutServlet), "/pca/signout");
            contextHander.addServlet(new ServletHolder( pcaInitServlet), "/pca/init");      
            contextHander.addServlet(new ServletHolder( pcaLogoutServlet), "/pca/logout");  
            contextHander.addServlet(new ServletHolder( pcaInfoServlet), "/pca/info");    
         try
   {
          System.out.println("server start");
    server.start();
    server.join();  
    System.out.println("server stop");
   } catch (Exception e)
   {
    e.printStackTrace();
   }  
 }
}

以上为个人经验希望能给大家一个参考也希望大家多多支持。


相关文章

猜您喜欢

  • Python 自动化办公 Python 自动化处理Excel和Word实现自动办公

    想了解Python 自动化处理Excel和Word实现自动办公的相关内容吗Python学习与数据挖掘在本文为您仔细讲解Python 自动化办公的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Python,自动化办公,Python,Excel,Python,Word下面大家一起来学习吧。..
  • Vue项目优化打包 Vue项目优化打包详解

    想了解Vue项目优化打包详解的相关内容吗CRMEB在本文为您仔细讲解Vue项目优化打包的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Vue项目,Vue优化,Vue打包下面大家一起来学习吧。..

网友评论

Copyright 2020 www.tdogsoftware.com 【零度软件园】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式