Spring依賴注入/構造函數注入/set方法注入/注入集合數據

Spring依賴注入/構造函數注入/set方法注入/注入集合數據

項目結構

在這裏插入圖片描述

配置文件

  1. pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.xiaoge</groupId>
        <artifactId>DI</artifactId>
        <version>1.0-SNAPSHOT</version>
        <packaging>jar</packaging>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
                <version>5.0.2.RELEASE</version>
            </dependency>
        </dependencies>
    
    </project>
    
  2. bean.xml**(注入的詳細, 解釋)**

    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans.xsd">
    
        <!-- spring中的依賴注入
             依賴注入:
                Dependency Injection
             IOC的作用:
                降低程序間的耦合(依賴關係)
             依賴關係的管理:
                以後都將給了spring來維護
             在當前類需要用到其他類的對象, 有spring爲我們提供, 我們只需要在配置文件中說明.
             依賴關係的維護:
                    就稱之爲依賴注入.
                 依賴注入:
                    能注入的數據: 有三類
                        基本類型和String
                        其他bean類型(在配置文件中 或者 註解配置過的bean)
                        複雜類型/集合類型
                    注入的方式: 有三種
                        第一種: 使用構造函數提供
                        第二種: 使用set方法提供
                        第三種: 使用註解提供
         -->
    
    
    
    
    
        <!-- 構造函數注入: (這種方式在實際開發中, 除非是必須, 要不然, 一般不會用)
                使用的標籤: constructor-arg
                標籤出現的位置: bean標籤的內容
                標籤中的屬性:
                    type: 用於指定要注入的數據類型, 該數據類型也是構造函數中某個或某些參數的類型
                    index: 用於指定要注入的數據給構造函數中指定索引位置的參數賦值. 索引的位置是從0開始
                    name: 用於指定給構造函數中指定名稱的參數賦值                                 (常用的)
                    ================以上三個用於指定給構造函數中那個參數賦值======================
                    value: 用於提供基本類型和String類型的數據
                    ref: 用於指定其他的bean類型數據. 它指的就是在spring的Ioc核心容器中出現過的bean對象
    
                優勢:
                    在獲取bean對象時, 注入數據是必須的操作, 否則對象無法創建成功.
                弊端:
                    改變了bean對象的實例化方式, 使我們在創建對象時. 如果用不到這些數據. 也必須提供.
         -->
        <bean id="accountService" class="com.xiaoge.service.impl.AccountServiceImpl">
            <constructor-arg name="name" value="哈哈"></constructor-arg>
            <constructor-arg name="age" value="18"></constructor-arg>
            <constructor-arg name="birthday" ref="now"></constructor-arg>
        </bean>
    
        <!-- 配置一個日期對象 -->
        <bean id="now" class="java.util.Date"></bean>
    
    
    
        <!-- set方法注入                更常用的方式
             涉及的標籤: property
             出現的位置: bean標籤的內部
             標籤的屬性:
                name: 用於指定注入時所調用的set方法名稱                                 (常用的)
                ================以上三個用於指定給構造函數中那個參數賦值======================
                value: 用於提供基本類型和String類型的數據
                ref: 用於指定其他的bean類型數據. 它指的就是在spring的Ioc核心容器中出現過的bean對象
             優勢:
                創建對象時沒有明確的限制, 可以直接使用默認構造函數
             弊端:
                如果有某個成員必須有值, 則獲取對象時有可能set方法沒有執行.
        -->
        <bean id="accountService2" class="com.xiaoge.service.impl.AccountServiceImpl2">
            <property name="name" value="嘻嘻"></property>
            <property name="age" value="20"></property>
            <property name="birthday" ref="now"></property>
        </bean>
    
    
    
        <!-- 複雜類型的注入/集合類型的注入
             用於給List結構集合注入的標籤:
                list array set
             用於給Map結構集合注入的標籤:
                map props
             總結: 結構相同, 標籤可以互換
        -->
        <bean id="accountService3" class="com.xiaoge.service.impl.AccountServiceImpl3">
            <property name="myStrs">
                <!-- 給數組注入值 -->
                <array>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </array>
            </property>
    
            <property name="myList">
                <!-- 給list集合注入值 -->
                <list>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </list>
            </property>
    
    
            <property name="mySet">
                <!-- 給Set集合注入值 -->
                <set>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </set>
            </property>
    
            <property name="myMap">
                <!-- 給Map集合注入值 -->
                <map>
                    <!-- entry的兩種寫法 -->
                    <entry key="map1" value="1"></entry>
                    <entry key="map2">
                        <value>2</value>
                    </entry>
                </map>
            </property>
    
    
            <property name="myProps">
                <!-- 給Properties集合注入值 -->
                <props>
                    <prop key="prop1">prop1</prop>
                    <prop key="prop2">prop2</prop>
                </props>
            </property>
    
        </bean>
    
    
    
    </beans>
    

業務層接口

  1. AccountService

    package com.xiaoge.service;
    
    /**
     * @Author: 瀟哥
     * @DateTime: 2020/3/19 下午7:26
     * @Description: 賬戶業務層接口
     */
    public interface AccountService {
    
        /**
         * 模擬保存
         */
        public void saveAccount();
    
    }
    
    

業務層實現類

  1. AccountServiceImpl**(構造函數注入)**

    package com.xiaoge.service.impl;
    
    import com.xiaoge.service.AccountService;
    
    import java.util.Date;
    
    /**
     * @Author: 瀟哥
     * @DateTime: 2020/3/19 下午7:28
     * @Description: 賬戶業務層實現類
     */
    public class AccountServiceImpl implements AccountService {
    
    
        /*
            定義可以注入的變量:
                注意: 如果是經常變化的數據, 並不適用於注入的方式
         */
        private String name;
        private Integer age;
        private Date birthday;
    
        public AccountServiceImpl(String name, Integer age, Date birthday) {
            this.name = name;
            this.age = age;
            this.birthday = birthday;
        }
    
        public void saveAccount() {
            System.out.println("service中的saveAccount方法執行了...." + name + ", " + age + ", " + birthday);
        }
    
    
    }
    
    
  2. AccountServiceImpl2**(set方法注入)**

    package com.xiaoge.service.impl;
    
    import com.xiaoge.service.AccountService;
    
    import java.util.Date;
    
    /**
     * @Author: 瀟哥
     * @DateTime: 2020/3/19 下午7:28
     * @Description: 賬戶業務層實現類
     */
    public class AccountServiceImpl2 implements AccountService {
    
    
        /*
            定義可以注入的變量:
                注意: 如果是經常變化的數據, 並不適用於注入的方式
         */
        private String name;
        private Integer age;
        private Date birthday;
    
        public void setName(String name) {
            this.name = name;
        }
    
        public void setAge(Integer age) {
            this.age = age;
        }
    
        public void setBirthday(Date birthday) {
            this.birthday = birthday;
        }
    
        public void saveAccount() {
            System.out.println("service中的saveAccount方法執行了...." + name + ", " + age + ", " + birthday);
        }
    
    
    }
    
  3. AccountServiceImpl3**(set方法注入集合數據)**

    package com.xiaoge.service.impl;
    
    import com.xiaoge.service.AccountService;
    
    import java.util.*;
    
    /**
     * @Author: 瀟哥
     * @DateTime: 2020/3/19 下午7:28
     * @Description: 賬戶業務層實現類
     */
    public class AccountServiceImpl3 implements AccountService {
        /*
            定義可以注入的變量:
                注意: 如果是經常變化的數據, 並不適用於注入的方式
         */
        private String[] myStrs;
        private List<String> myList;
        private Set<String> mySet;
        private Map<String, String> myMap;
        private Properties myProps;
    
        public void setMyStrs(String[] myStrs) {
            this.myStrs = myStrs;
        }
    
        public void setMyList(List<String> myList) {
            this.myList = myList;
        }
    
        public void setMySet(Set<String> mySet) {
            this.mySet = mySet;
        }
    
        public void setMyMap(Map<String, String> myMap) {
            this.myMap = myMap;
        }
    
        public void setMyProps(Properties myProps) {
            this.myProps = myProps;
        }
    
        public void saveAccount() {
            System.out.println(Arrays.toString(myStrs));
            System.out.println(myList);
            System.out.println(mySet);
            System.out.println(myMap);
            System.out.println(myProps);
        }
    
    
    }
    

main

  1. Client

    package com.xiaoge.ui;
    
    import com.xiaoge.service.AccountService;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    /**
     * @Author: 瀟哥
     * @DateTime: 2020/3/19 下午7:35
     * @Description: 模擬表現層, 調用業務層
     */
    public class Client {
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            // 1. 獲取核心容器對象
            ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("bean.xml");
    
            // 2. 獲取對象
            AccountService as = (AccountService)applicationContext.getBean("accountService3");
    
            // 3. 執行方法
            as.saveAccount();
    
            // 4. 手動釋放容器
            applicationContext.close();
          
          	// 運行結果
          	[AAA, BBB, CCC]
    				[AAA, BBB, CCC]
    				[AAA, BBB, CCC]
    				{map1=1, map2=2}
    				{prop2=prop2, prop1=prop1}
    
        }
    
    
    
    }
    
    
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章