程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> C#反射技術之讀取和設置類的屬性

C#反射技術之讀取和設置類的屬性

編輯:關於C#

要用C#反射技術的話,首先得引入System.Reflection 命名空間,這個命名空間裡的類,具有動態加載程序集、類型,動態調用方法、設置和取得屬性和字段的值、可以獲取類型和方法的信息的功能。

要想對一個類型實例的屬性或字段進行動態賦值或取值,首先得得到這個實例或類型的Type,微軟已經為我們提供了足夠多的方法。

1 Class MyClass
2 {
3 private int field;
4 public int Field
5 {
6 get
7 {
8 return this.field;
9 }
10 set
11 {
12 this.field = value;
13 }
14 }
15 }

如果有個這個類型的實例:

MyClass myObj = new MyClass();

我們要動態的為這個實例的屬性Field賦值,那麼得先得到這個實例的類型:

Type t=typeof(MyClass);另一種方法是:

Type t=myObj.GetType();只要我們得到了對象的類型那麼我們就可以利用反射對這個對象“為所欲為”了,哈哈。

t.GetProperty("Field").SetValue(myObj,1,null);這樣我們就為對象裡的屬性Field賦值了。如果把屬性名和要賦的值寫道配置文件裡的話,我們就可以達到程序運行期間動態的為屬性賦值了。

利用反射獲取屬性值的方法:

int propValue=Convert.ToInt32(t.GetProperty("Field").SetValue(myObj,null));好了,關於利用反射動態的為對象的屬性賦值取值就到這裡了。

(C#)利用反射動態調用類成員

使用反射動態調用類成員,需要Type類的一個方法:InvokeMember。對該方法的聲明如下:

public object InvokeMember(
 string name,
 BindingFlags invokeAttr,
 Binder binder,
 object target,
 object[] args
);

參數

name

String,它包含要調用的構造函數、方法、屬性或字段成員的名稱。

- 或 -

空字符串 (""),表示調用默認成員。

invokeAttr

一個位屏蔽,由一個或多個指定搜索執行方式的 BindingFlags 組成。訪問可以是 BindingFlags 之一,如 Public、NonPublic、Private、InvokeMethod 和 GetField 等。不需要指定查找類型。如果省略查找類型,則將應用 BindingFlags.Public | BindingFlags.Instance。

binder

一個 Binder 對象,該對象定義一組屬性並啟用綁定,而綁定可能涉及選擇重載方法、強制參數類型和通過反射調用成員。

- 或 -

若為空引用(Visual Basic 中為 Nothing),則使用 DefaultBinder。

target

要在其上調用指定成員的 Object。

args

包含傳遞給要調用的成員的參數的數組。

返回值

表示被調用成員的返回值的 Object。

備注:

下列 BindingFlags 篩選標志可用於定義包含在搜索中的成員:

為了獲取返回值,必須指定 BindingFlags.Instance 或 BindingFlags.Static。

指定 BindingFlags.Public 可在搜索中包含公共成員。

指定 BindingFlags.NonPublic 可在搜索中包含非公共成員(即私有成員和受保護的成員)。

指定 BindingFlags.FlattenHierarchy 可包含層次結構上的靜態成員。

下列 BindingFlags 修飾符標志可用於更改搜索的執行方式:

BindingFlags.IgnoreCase,表示忽略 name 的大小寫。

BindingFlags.DeclaredOnly,僅搜索 Type 上聲明的成員,而不搜索被簡單繼承的成員。

可以使用下列 BindingFlags 調用標志表示要對成員采取的操作:

CreateInstance,表示調用構造函數。忽略 name。對其他調用標志無效。

InvokeMethod,表示調用方法,而不調用構造函數或類型初始值設定項。對 SetField 或 SetProperty 無效。

GetField,表示獲取字段值。對 SetField 無效。

SetField,表示設置字段值。對 GetField 無效。

GetProperty,表示獲取屬性。對 SetProperty 無效。

SetProperty 表示設置屬性。對 GetProperty 無效。

下面通過例題對該方法進行簡單應用(我一直以為,要讓例題起到更容易理解文字的意義和作用,撰寫的例題越簡單越直觀越好。)

using System;
using System.Reflection;
&nb
 namespace ConsoleApplication9
{
  class Love
  {
    public int field1;
    private string _name;
    public Love()
    {
    }
    public string Name
    {
      get
      {
        return _name;
}
      set
      {
        _name=value;
      }
    }
    public int GetInt(int a)
    {
      return a;
    }
    public void Display(string str)
    {
      Console.WriteLine(str);
    }
  }
  /// <summary>
  /// Class1 的摘要說明。
  /// </summary>
  class Class1
  {
    /// <summary>
    /// 應用程序的主入口點。
    /// </summary>
    [STAThread]
    static void Main(string[] args)
    {
      //
      // TODO: 在此處添加代碼以啟動應用程序
      //
      Love love = new Love();
      Type type = love.GetType();
      Object obj = type.InvokeMember(null,
        BindingFlags.DeclaredOnly |
        BindingFlags.Public | BindingFlags.NonPublic |
        BindingFlags.Instance | BindingFlags.CreateInstance, null, null, args);
      //調用沒有返回值的方法
      type.InvokeMember("Display",BindingFlags.InvokeMethod | BindingFlags.Public | BindingFlags.Instance , null , obj , new object[]{"aldfjdlf"});
      //調用有返回值的方法
      int i = (int)type.InvokeMember("GetInt",BindingFlags.InvokeMethod | BindingFlags#0000cc">.Public | BindingFlags.Instance,null,obj,new object[]{1});
Console.WriteLine(i);
      //設置屬性值
      type.InvokeMember("Name",BindingFlags.SetProperty,null,obj,new string[]{"abc"});
      //獲取屬性值
      string str=(string)type.InvokeMember("Name",BindingFlags.GetProperty,null,obj,null);
      Console.WriteLine(str);
      //設置字段值
      type.InvokeMember("field1",BindingFlags.SetField,null,obj,new object[]{444});
      //獲取字段值
      int f=(int)type.InvokeMember("field1",BindingFlags.GetField,null,obj,null);
      Console.WriteLine(f);
      Console.ReadLine();
    }
  }
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved