Spring黑馬:四類註解

1.在bean.xml中配置context約束

1.曾經的XML配置:
 * <bean id="accountService" class="com.jh.service.impl.AccountServiceImpl"
 * scope=""  init-method=""  destroy-method="">
 * <property name="" value=""|ref=""></property>
 * </bean>

2. 不再是bean約束
註解配置:告知spring在創建容器時要掃描的包 com.jh

<?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"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    <!--註解配置:告知spring在創建容器時要掃描的包,配置所需要的標籤不是在beans的約束中,而是一個名稱爲
    context名稱空間和約束中-->
    <context:component-scan base-package="com.jh"></context:component-scan>
</beans>

2. 四類註解

2.1 用於創建對象的註解

概念:他們的作用就和在XML配置文件中編寫一個<bean標籤>實現的功能是一樣的;
(1) @Component
作用:用於把當前類對象存入spring容器中;
屬性:value:用於指定bean的id。當我們不寫時,它的默認值是當前類名,且首字母改小寫。在這裏插入圖片描述
(2) @Controller:一般用在表現層
(3) @Service:一般用在業務層
(4) @Repository:一般用在持久層
在這裏插入圖片描述
以上三個註解他們的作用和屬性與Component是一模一樣
他們三個是spring框架爲我們提供明確的三層使用的註解,使我們的三層對象更加清晰。

2.2 用於注入數據的註解

概念:他們的作用就和在xml配置文件中的bean標籤中寫一個<property>標籤的作用是一樣的;

  • (1)Autowired:
    作用:自動按照類型注入。只要容器中有唯一的一個bean對象類型和要注入的變量類型匹配,就可以注入成功;
    在這裏插入圖片描述
  • 如果ioc容器中沒有任何bean的類型和要注入的變量類型(IAccountDao)匹配,則報錯:
    ------(如://@Repository(“accountDao1”)不把當前類對象存入spring容器中,就不能尋找一個bean對象類型;
    //implements IAccountDao 尋找不到IAccountDao類型匹配)。在這裏插入圖片描述
  • 如果Ioc容器中有多個類型匹配時:(先查看注入變量名稱accountDao1和@Repository(“accountDao1”)id是否相等,相等則匹配,其次再查看變量類型)。
    在這裏插入圖片描述
  • 出現位置:可以是變量上,也可以是方法上
  • 細節:在使用註解注入時,set方法就不是必須的了。
  • (2)Qualifier:
    作用:在按照類中注入的基礎之上再按照名稱注入。它在給類成員注入時不能單獨使用,要和Autowired一起用
    但是在給方法參數注入時可以(稍後我們講)
  • 屬性:value:用於指定注入bean的id。
    在這裏插入圖片描述
  • (3)Resource:
    作用:直接按照bean的id注入。它可以獨立使用。
  • 屬性:name:用於指定bean的id。
    在這裏插入圖片描述

以上三個注入都只能注入其他bean類型的數據,而基本類型和String類型無法使用上述註解實現。另外,集合類型的注入只能通過XML來實現

  • (4)Value:
    作用:用於注入基本類型和String類型的數據
  • 屬性:value:用於指定數據的值。它可以使用spring中SpEL(也就是spring的el表達式)SpEL的寫法:${表達式}

2.3 用於改變作用範圍的註解

概念:他們的作用就和在bean標籤中使用scope屬性實現的功能是一樣的;
@Scope
作用:用於指定bean的作用範圍
屬性:value:指定範圍的取值。常用取值:singleton prototype
在這裏插入圖片描述

2.4 和生命週期有關的註解

概念:他們的作用就和在bean標籤中使用init-methoddestroy-methode的作用是一樣的;

@PreDestroy 作用:用於指定銷燬方法
@PostConstruct 作用:用於指定初始化方法
在這裏插入圖片描述

3. 四類註解的程序

1.com\jh\dao\impl下的2個持久層實現類
AccountDaoImpl.java

package com.jh.dao.impl;
import com.jh.dao.IAccountDao;
import org.springframework.stereotype.Repository;
/**
 * 賬戶的持久層實現類
 */
@Repository("accountDao1")
public class AccountDaoImpl implements IAccountDao {
    public  void saveAccount(){
        System.out.println("保存了賬戶 accountDao1......");
    }
}

AccountDaoImpl2.java

package com.jh.dao.impl;
import com.jh.dao.IAccountDao;
import org.springframework.stereotype.Repository;
/**
 * 賬戶的持久層實現類
 */
@Repository("accountDao2")
public class AccountDaoImpl2 implements IAccountDao {
    public  void saveAccount(){
        System.out.println("保存了賬戶 accountDao2.....");
    }
}

2.com\jh\dao持久層接口

package com.jh.dao;
/**
 * 賬戶的持久層接口
 */
public interface IAccountDao {
    void saveAccount();
}

3.com\jh\service\impl業務層的實現類

package com.jh.service.impl;
import com.jh.dao.IAccountDao;
import com.jh.dao.impl.AccountDaoImpl;
import com.jh.service.IAccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.annotation.Resource;
@Component("accountService")
@Scope("singleton")// 單例模式
public class AccountServiceImpl implements IAccountService {
    //@Autowired//該註解解決空指針異常了
    /*@Autowired
    @Qualifier("accountDao1")*/
    @Resource(name = "accountDao2")
    private IAccountDao accountDao=null;

    @PostConstruct
    public void init(){
        System.out.println("初始化方法執行了");
    }
    @PreDestroy
    public void destroy(){
        System.out.println("銷燬方法執行了");
    }

    public AccountServiceImpl(){
        System.out.println("對象創建了");
    }
    public void  saveAccount(){
        accountDao.saveAccount();
    }
}

4.com\jh\service業務層的接口

package com.jh.service;
/**
 * 賬戶業務層的接口
 */
public interface IAccountService {
    void saveAccount();
}

5.com\jh\ui表現層

package com.jh.ui;
import com.jh.dao.IAccountDao;
import com.jh.service.IAccountService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
 * 模擬一個表現層,用於調用業務層
 * */
public class Client {
    public static void main(String[] args) {
        //--------ApplicationContext 立即加載----------------------
        //1.獲取核心容器對象
        ApplicationContext ac= new ClassPathXmlApplicationContext("bean.xml");
        //2.根據id獲取Bean對象
        IAccountService as= (IAccountService)ac.getBean("accountService");
        System.out.println(as);
        as.saveAccount();

        /*IAccountDao adao= (IAccountDao) ac.getBean("accountDao");
        System.out.println(adao);*/
        }
    }
發佈了95 篇原創文章 · 獲贊 15 · 訪問量 6108
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章