目錄
反射" >反射
IOC" >IOC

反射與IOC

Feb 23, 2017 am 09:46 AM

反射

  反射機制是在運作狀態中,對於任一類,都能夠知道這個類別的所有屬性和方法;對於任意一個對象,都能夠呼叫它的任意一個方法;這種動態取得的以及動態呼叫對象的方法的功能稱為反射機制。反射機制動態獲取方法並使用方法和自己直接創建一個類別的物件去直接呼叫時完全不一樣的。例如一個類別裡面有一個屬性為private的屬性或是方法,我們是不能直接去呼叫的,但是可以使用反射機制去動態呼叫。

IOC

#  IOC最大的優點就是把物件產生放在了XML裡定義,所以當我們需要換一個實作子類別將會變成很簡單(一般這樣的物件都是實作於某種介面的),只要修改XML就可以了,這樣我們甚至可以實現物件的熱插撥(有點象USB介面和SCSI硬碟了)。在不適用IOC之前一個物件如果依賴另一個物件(後面我們簡稱依賴物件和被依賴物件),我們要在依賴物件中實例化一個被依賴對象,這樣才能呼叫被依賴物件中的方法。顯然這樣耦合度比較高,不符合我們程式設計的原則。因此這時候我們就會引入一個第三方對象,它負責直接傳遞一個依賴對象,降低二者之間的耦合性給依賴對象。下圖是加入IOC容器前後,系統中物件耦合度的比較

  





#  軟體系統在沒有引入IOC容器之前,如圖1所示,物件A依賴物件B,那麼物件A在初始化或運作到某一點的時候,自己必須主動去創建物件B或使用已經建立的物件B。無論是創建還是使用物件B,控制權都在自己手上。

軟體系統在引入IOC容器之後,這種情況就完全改變了,如圖2所示,由於IOC容器的加入,對象A與對象B之間失去了直接聯繫,所以,當對象A運行到需要物件B的時候,IOC容器會主動建立一個物件B注入到物件A需要的地方。

透過前後的對比,我們不難看出來:物件A獲得依賴物件B的過程,由主動行為變為了被動行為,控制權顛倒過來了,這就是「控制反轉」這個名稱的由來。

實例


#反射實例程式碼

#
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace StudentDAL
{
    public class Student
    {
        //属性
        public string Name{get;set;}
        public int Age { get; set; }

        //无参数构造函数
        public Student()
        {
            this.Name = "无参数";
            this.Age = 0;

        }
        //有参数构造函数
        public Student(string name, int age)
        {
            this.Name = "name";
            this.Age = age;
        }

        //public带参带返回值函数
        public string PublishMethodReturn()
        {
            return string.Format("我叫"+Name+"年龄" +Age);
        }
    }
}</strong></span>
登入後複製
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Reflection;

namespace ITOO_Reflection
{
    class Program
    {
        static void Main(string[] args)
        {
            //使用 Assembly 定义和加载程序集,
            //加载在程序集清单中列出的模块,
            //以及从此程序集中查找类型并创建该类型的实例.
            //获取程序集
            Assembly assembly = Assembly.Load("StudentDAL");
            //从程序及获取指定对象类型
            Type type = assembly.GetType("StudentDAL.Student");
            var instance = assembly.CreateInstance("StudentDAL.Student");
            //为学生类的属性赋值
            type.GetProperty("Name").SetValue(instance, "shx", null);
            type.GetProperty("Age").SetValue(instance, 18, null);
            //获取Student类的方法
            var method = type.GetMethod("PublishMethodReturn");
            //调用Student类的成员方法PublishMethodReturn
            var S= method.Invoke(instance, null);
          
            Console.WriteLine(S);
            Console.Read();
        }
    }
}</strong></span>
登入後複製

#運行結果






##IOC實例程式碼




#

<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ITOO.IOC.IDAL
{
    public interface IUserDal
    {
        void HelloWord();
    }
}
</strong></span>
登入後複製
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ITOO.IOC.IDAL;

namespace ITOO.IOC.DAL
{
    public class User:IUserDal
    {
        public void HelloWord()
        {
            Console.WriteLine("helloword");
        }
    }
}
</strong></span>
登入後複製
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ITOO.IOC.IBLL
{
    public interface IUserBll
    {
        void HelloWord();
    }
}
</strong></span>
登入後複製
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ITOO.IOC.IBLL;
using ITOO.IOC.IDAL;
using ITOO.Library.Core.AOP;

namespace ITOO.IOC.BLL
{
    public class UserBll:IUserBll
    {
        public void HelloWord()
        {
            //使用底层封装的SpringHelper从IOC容器中拿到D层的类的对象实例
            IUserDal iuser = SpringHelper.GetObject<IUserDal>("User");
            iuser.HelloWord();
        }
    }
}
</strong></span>
登入後複製
<span style="font-family:KaiTi_GB2312;font-size:18px;color:#666666;"><strong>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ITOO.IOC.IBLL;
using ITOO.Library.Core.AOP;

namespace ITOO.IOC.Client
{
    class Program
    {
        static void Main(string[] args)
        {
            //客户端通过底层封装的SpringHelper从IOC容器中根据B层类的对象的id拿到UserBll类的实例
            IUserBll iuserbll = SpringHelper.GetObject<IUserBll>("UserBll");
            //调用UserBll类的方法
            iuserbll.HelloWord();
            Console.Read();
        }
    }
}
</strong></span>
登入後複製
############# ###執行結果###################################################### ############ 以上就是反射與IOC的內容,更多相關內容請關注PHP中文網(www.php.cn)! ###############################
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java 中介面和抽象類別的反射機制實現 Java 中介面和抽象類別的反射機制實現 May 02, 2024 pm 05:18 PM

反射機制允許程式在執行時間取得和修改類別訊息,它可用於實作介面和抽象類別的反射:介面的反射:透過Class.forName()取得介面反射對象,存取其元資料(名稱、方法和欄位) 。抽象類別的反射:與介面類似,可取得抽象類別的反射對象,存取其元資料以及非抽象方法。實戰案例:反射機制可用於實作動態代理,透過動態建立代理類別在執行時攔截對介面方法的呼叫。

golang 如何使用反射存取私有欄位和方法 golang 如何使用反射存取私有欄位和方法 May 03, 2024 pm 12:15 PM

Go語言中可以使用反射來存取私有欄位和方法:存取私有欄位:透過reflect.ValueOf()取得值的反射值,再使用FieldByName()取得欄位的反射值,並呼叫String()方法列印欄位的值。呼叫私有方法:同樣透過reflect.ValueOf()取得值的反射值,再使用MethodByName()取得方法的反射值,最後呼叫Call()方法執行方法。實戰案例:透過反射修改私有欄位值和呼叫私有方法,實現物件的控制和單元測試覆寫。

golang 反射的安全性考量和最佳方案 golang 反射的安全性考量和最佳方案 May 04, 2024 pm 04:48 PM

反射在Go中提供類型檢查和修改功能,但存在安全隱患,包括任意程式碼執行、類型偽造和資料外洩。最佳方案包括限制反射權限、操作、使用白名單或黑名單、驗證輸入以及使用安全工具。實務中,反射可安全用於檢查類型資訊。

golang 如何使用反射動態修改變數值 golang 如何使用反射動態修改變數值 May 02, 2024 am 11:09 AM

Go語言反射允許在運行時操控變數值,包括修改布林值、整數、浮點數和字串。透過取得變數的Value,可以呼叫SetBool、SetInt、SetFloat和SetString方法來進行修改。例如,可以解析JSON字串為結構體,然後使用反射修改結構體欄位的值。需要注意,反射操作較慢,且無法修改不可修改字段,修改結構體字段值時可能不會自動更新相關字段。

Golang反射介紹及應用場景分析 Golang反射介紹及應用場景分析 Apr 03, 2024 pm 01:45 PM

Go語言中的反射功能可讓程式在執行時間檢查和修改類型的結構。透過使用Type、Value和reflect.Kind,我們可以取得物件的類型資訊、欄位值和方法,還可以建立和修改物件。具體的操作方法包括:檢查類型(TypeOf())、取得欄位值(ValueOf()、FieldByName())、修改欄位值(Set())、建立物件(New())。

IOC在Go語言中的實現與實踐:控制反轉詳解 IOC在Go語言中的實現與實踐:控制反轉詳解 Apr 07, 2024 pm 02:33 PM

控制反轉是一種設計模式,將物件建立和依賴關係管理從客戶端程式碼轉移到容器中,提高程式碼靈活性和可測試性。 Go語言中IOC的實作可以使用wire框架,具體步驟包括:定義介面、定義類型、使用wire函數。透過使用wire產生的容器,可以獲得提高可測試性、靈活性以及簡化配置的優點。

golang函數利用反射實現面向切面的編程 golang函數利用反射實現面向切面的編程 Apr 25, 2024 pm 05:48 PM

答案:是的,Go語言中的反射可以實現面向切面的程式設計。詳細描述:反射允許程式在運行時修改和檢查自己的類型和值。透過反射,我們可以為程式碼創建全域切面,在函數執行前、後觸發。這使我們能夠輕鬆新增日誌記錄等功能,而無需修改現有程式碼。反射提供了程式碼解耦、可擴展性以及靈活控制的優點,從而提高了應用程式的可維護性和可重用性。

golang 如何使用反射建立新類型 golang 如何使用反射建立新類型 May 01, 2024 am 09:21 AM

利用反射,Go允許建立新類型,1.使用reflect.TypeOf()取得現有類型的reflect.Type值;2.使用reflect.New()建立新類型的指標值;3.透過*Ptr.Elem( )存取實際值;4.反射還可以根據字串動態建立新類型,用於建立靈活且動態的程式。

See all articles