您好,登錄后才能下訂單哦!
本篇內容介紹了“Spring注解開發怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
說明
在spring4之后,想要使用注解形式,必須得要引入aop的包
在配置文件當中,還得要引入一個context約束
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> </beans>
我們之前都是使用 bean 的標簽進行bean注入,但是實際開發中,我們一般都會使用注解!
1、配置掃描哪些包下的注解
<context:component-scan base-package="com.hc.pojo"/>
2、在指定包下編寫類,增加注解
@Component("user") // 相當于配置文件中 <bean id="user" class="當前注解的類"/> public class User { public String name = "秦疆"; }
3、測試
@Test public void test(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml"); User user = (User) applicationContext.getBean("user"); System.out.println(user.name); }
使用注解注入屬性
1、可以不用提供set方法,直接在直接名上添加@value(“值”)
@Component("user") // 相當于配置文件中 <bean id="user" class="當前注解的類"/> public class User { @Value("秦疆") // 相當于配置文件中 <property name="name" value="秦疆"/> public String name; }
2、如果提供了set方法,在set方法上添加@value(“值”);
@Component("user") public class User { public String name; @Value("秦疆") public void setName(String name) { this.name = name; } }
我們這些注解,就是替代了在配置文件當中配置步驟而已!更加的方便快捷!
@Component三個衍生注解
為了更好的進行分層,Spring可以使用其它三個注解,功能一樣,目前使用哪一個功能都一樣。
@Controller:controller層
@Service:service層
@Repository:dao層
寫上這些注解,就相當于將這個類交給Spring管理裝配了!
在Bean的自動裝配已經講過了,可以回顧!
@scope
singleton:默認的,Spring會采用單例模式創建這個對象。關閉工廠 ,所有的對象都會銷毀。
prototype:多例模式。關閉工廠 ,所有的對象不會銷毀。內部的垃圾回收機制會回收
@Controller("user") @Scope("prototype") public class User { @Value("秦疆") public String name; }
XML與注解比較
XML可以適用任何場景 ,結構清晰,維護方便
注解不是自己提供的類使用不了,開發簡單方便
xml與注解整合開發 :推薦最佳實踐
xml管理Bean
注解完成屬性注入
使用過程中, 可以不用掃描,掃描是為了類上的注解
<context:annotation-config/>
作用:
進行注解驅動注冊,從而使注解生效
用于激活那些已經在spring容器里注冊過的bean上面的注解,也就是顯示的向Spring注冊
如果不掃描包,就需要手動配置bean
如果不加注解驅動,則注入的值為null!
JavaConfig 原來是 Spring 的一個子項目,它通過 Java 類的方式提供 Bean 的定義信息,在 Spring4 的版本, JavaConfig 已正式成為 Spring4 的核心功能 。
測試:
1、編寫一個實體類,Dog
@Component //將這個類標注為Spring的一個組件,放到容器中! public class Dog { public String name = "dog"; }
2、新建一個config配置包,編寫一個MyConfig配置類
@Configuration //代表這是一個配置類 public class MyConfig { @Bean //通過方法注冊一個bean,這里的返回值就Bean的類型,方法名就是bean的id! public Dog dog(){ return new Dog(); } }
3、測試
@Test public void test2(){ ApplicationContext applicationContext = new AnnotationConfigApplicationContext(MyConfig.class); Dog dog = (Dog) applicationContext.getBean("dog"); System.out.println(dog.name); }
4、成功輸出結果!
導入其他配置如何做呢?
1、我們再編寫一個配置類!
@Configuration //代表這是一個配置類 public class MyConfig2 { }
2、在之前的配置類中我們來選擇導入這個配置類
@Configuration @Import(MyConfig2.class) //導入合并其他配置類,類似于配置文件中的 inculde 標簽 public class MyConfig { @Bean public Dog dog(){ return new Dog(); } }
“Spring注解開發怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。