使用反射实现延迟绑定

反射允许我们在编译期或运行时获取程序集的元数据,通过反射可以做到:
● 创建类型的实例
● 触发方法
● 获取属性、字段信息
● 延迟绑定
......

如果在编译期使用反射,可通过如下2种方式获取程序集Type类型:
1、Type类的静态方法
Type type = Type.GetType("somenamespace.someclass");

2、通过typeof
Type type = typeof(someclass);

如果在运行时使用反射,通过运行时的Assembly实例方法获取Type类型:

Type type = asm.GetType("somenamespace.someclass");

获取反射信息

有这样的一个类:

public class Student
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public float Score { get; set; }

        public Student()
        {
            this.Id = -1;
            this.Name = string.Empty;
            this.Score = 0;
        }

        public Student(int id, string name, float score)
        {
            this.Id = id;
            this.Name = name;
            this.Score = score;
        }

        public string DisplayName(string name)
        {
            return string.Format("学生姓名:{0}", name);
        }

        public void ShowScore()
        {
            Console.WriteLine("学生分数是:" + this.Score);
        }
    }

通过如下获取反射信息:

static void Main(string[] args)
        {
            Type type = Type.GetType("ConsoleApplication1.Student");
            //Type type = typeof (Student);

            Console.WriteLine(type.FullName);
            Console.WriteLine(type.Namespace);
            Console.WriteLine(type.Name);

            //获取属性
            PropertyInfo[] props = type.GetProperties();
            foreach (PropertyInfo prop in props)
            {
                Console.WriteLine(prop.Name);
            }

            //获取方法
            MethodInfo[] methods = type.GetMethods();
            foreach (MethodInfo method in methods)
            {
                Console.WriteLine(method.ReturnType.Name);
                Console.WriteLine(method.Name);
            }
            Console.ReadKey();
        }

延迟绑定

在通常情况下,为对象实例赋值是发生在编译期,如下:

Student stu = new Student();
stu.Name = "somename";

而"延迟绑定",为对象实例赋值或调用其方法是发生在运行时,需要获取在运行时的程序集、Type类型、方法、属性等。

//获取运行时的程序集
            Assembly asm = Assembly.GetExecutingAssembly();

            //获取运行时的Type类型
            Type type = asm.GetType("ConsoleApplication1.Student");

            //获取运行时的对象实例
            object stu = Activator.CreateInstance(type);

            //获取运行时指定方法
            MethodInfo method = type.GetMethod("DisplayName");
            object[] parameters = new object[1];
            parameters[0] = "Darren";

            //触发运行时的方法
            string result = (string)method.Invoke(stu, parameters);
            Console.WriteLine(result);
            Console.ReadKey();

使用反射实现延迟绑定,布布扣,bubuko.com

时间: 2024-10-25 09:22:46

使用反射实现延迟绑定的相关文章

[WinForm] 使用反射将业务对象绑定到窗体或控件容器

在WebForm中,可以使用反射将业务对象绑定到 ASP.NET 窗体控件.最近做Winform项目,也参考WebForm中的代码实现同样的功能.     Winform没有提供类似WebForm中的FindControl方法,我于是用遍历控件的方式,写了一个类似WebForm中的这个方法,考虑到Winform中的很多控件放在Label.TabControl中,方法采用了递归的方式.     Winform和Winform的控件也有些区别,如在Winform中,DateTimePicker取值是

Scala学习之延迟绑定

1 package com.swust.example 2 3 object TraitDemo2 extends App{ 4 5 //抽象类 6 abstract class Writer { 7 def writeMessage(message: String) 8 } 9 /** 10 * 继承这个抽象类,并且用super调用了这个抽象方法 11 * scala要求将方法声明为abstract override 12 * override告诉scala要为基类的一个已知方法提供一个实现

PHP 延迟绑定

1 class product{ 2 public static function create(){ 3 return new static(); 4 } 5 } 6 7 class food extends product{ 8 9 } 10 11 var_dump(food::create()); 12 //food::out(); 以上代码输出:object(food)#1 (0) { } class product{ public static function create(){ r

scala学习手记34 - trait方法的延迟绑定

trait的方法的延迟绑定就是先混入的trait的方法会后调用.这一点从上一节的实例中也可以看出来. 下面再来看一个类似的例子: abstract class Writer { def write(message: String): String } trait UpperWriter extends Writer { abstract override def write(message: String): String = super.write(message.toUpperCase) }

PHP静态延迟绑定简单示例

没怎么用过这个新特性,其实也不算新啦,试试吧,现在静态类的继承很方便了 <?php class A { protected static $def = '123456'; public static function test() { echo get_class(new static); } public static function test2() { echo static::$def; } } class B extends A { protected static $def = '4

数据持久化、单例、重载【添加对不可访问的成员的操作】、魔术方法、类常量、static关键字对self的补充【静态延迟绑定实现$this的效果】、参数类型约束【参数前加类名】、遍历【iterator接口】、快速排序

1.数据持久化过程[传输(例如表单提交或php交互mysql)和保存过程] 使用的是字符串形式的流数据. 数据流就是为了传输[按照序列的形式进行传输] [http://baike.baidu.com/link?url=0MtUQMhFzc_EwJc09rXZV8KlfOL4jis6XNbRfmGA3rQhDcGwOp8togLVQjXBV34M] 所以将其他类型数据转化为字符串的过程也是序列化的过程 [这个概念和图片.视频的流媒体的区别?] [注意点] 另外mysql中sql语句中的某些关键词为

PHP静态延迟绑定和普通静态效率简单对比

只是一个简单的小实验,对比了下 延迟绑定 和 非延迟的效率 延迟绑定主要就是使用 static 关键字来替代原来的 self ,但功能非常强大了 实验代码: class A { protected static $cc1 = array('a1', 'b', 'c', 'd'); protected static $cc2 = array('a2', 'b', 'c', 'd'); protected static $cc3 = array('a3', 'b', 'c', 'd'); prote

被忽略的魔法——php引用之延迟赋值(后期数据延迟绑定)

看到这个主题大家知道我今天要说的是php的变量引用特性,但是延迟赋值又是怎么回事呢?这个主要是我近期优化一些功能时的一个想法,我觉得还算不错,就打算记录下来.看一下下面的伪代码: // 这段代码有人会说为啥不用联表,因为有些业务需求不用联表的效率是联表的3到20倍 // 我的项目里基本都是此类写法,比之前联表效率提升很多 $a = DB::query("select id from a"); $aid = ""; foreach($a as $v){ $aid .=

通过工厂模式来认识PHP的静态延迟绑定

通过简单的工厂模式来认识PHP的静态延迟绑定 <?php abstract class Demo {     public static $name = 'sallency';          //error     public static function selfInstance() {         //self是用来解析上下文         //此处的语境为调用定义它的类         //抽象类不可实例化所以会报错         return new self();