Spring超詳細講解注解開發(fā)
1.使用注解開發(fā)
說明
在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>1.1.Bean的實現(xiàn)
我們之前都是使用 bean 的標簽進行bean注入,但是實際開發(fā)中,我們一般都會使用注解!
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.2.屬性注入
使用注解注入屬性
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;
}
}1.3.衍生注解
我們這些注解,就是替代了在配置文件當中配置步驟而已!更加的方便快捷!
@Component三個衍生注解
為了更好的進行分層,Spring可以使用其它三個注解,功能一樣,目前使用哪一個功能都一樣。
- @Controller:controller層
- @Service:service層
- @Repository:dao層
寫上這些注解,就相當于將這個類交給Spring管理裝配了!
1.4.自動裝配注解
在Bean的自動裝配已經講過了,可以回顧!
1.5.作用域
@scope
- singleton:默認的,Spring會采用單例模式創(chuàng)建這個對象。關閉工廠 ,所有的對象都會銷毀。
- prototype:多例模式。關閉工廠 ,所有的對象不會銷毀。內部的垃圾回收機制會回收
@Controller("user")
@Scope("prototype")
public class User {
@Value("秦疆")
public String name;
}1.6.小結
XML與注解比較
- XML可以適用任何場景 ,結構清晰,維護方便
- 注解不是自己提供的類使用不了,開發(fā)簡單方便
xml與注解整合開發(fā) :推薦最佳實踐
- xml管理Bean
- 注解完成屬性注入
- 使用過程中, 可以不用掃描,掃描是為了類上的注解
<context:annotation-config/>
作用:
- 進行注解驅動注冊,從而使注解生效
- 用于激活那些已經在spring容器里注冊過的bean上面的注解,也就是顯示的向Spring注冊
- 如果不掃描包,就需要手動配置bean
- 如果不加注解驅動,則注入的值為null!
2.基于Java類進行配置
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();
}
}關于這種Java類的配置方式,我們在之后的SpringBoot 和 SpringCloud中還會大量看到,我們需要知道這些注解的作用即可!
到此這篇關于Spring超詳細講解注解開發(fā)的文章就介紹到這了,更多相關Spring注解開發(fā)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
IDEA報錯:Unable to save settings Failed to save settings
這篇文章主要介紹了IDEA報錯:Unable to save settings Failed to save settings的相關知識,本文給大家分享問題原因及解決方案,需要的朋友可以參考下2020-09-09
解決Maven無法下載2.1.7.js7版本的itext依賴問題
本文主要解決使用Maven編譯項目時出現(xiàn)的itext依賴版本問題,通過分析,發(fā)現(xiàn)該問題是由jasperreports依賴的特定版本itext導致的,解決方法是排除jasperreports中的itext依賴,并自行指定更高版本的itext依賴2024-12-12
Java異常處理之java.lang.ClassCastException問題
這篇文章主要介紹了Java異常處理之java.lang.ClassCastException問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
java字符串日期類Date和Calendar相互轉化及相關常用方法
Java語言的Calendar(日歷),Date(日期),和DateFormat(日期格式)組成了Java標準的一個基本但是非常重要的部分,下面這篇文章主要給大家介紹了關于java字符串日期類Date和Calendar相互轉化及相關常用方法的相關資料,需要的朋友可以參考下2023-12-12
Java源碼解析HashMap的tableSizeFor函數(shù)
今天小編就為大家分享一篇關于Java源碼解析HashMap的tableSizeFor函數(shù),小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01

