反射为了动态(运行时动态)
原理:读取metadata(?)
 
Assembly assembly = Assembly.Load("TestReflections");//反射的入口 动态加载DLL
 
foreach (Module item in assembly.GetModules()){}//按照命名空间 决定循环次数
//GetTypes() //类型 类的名字
 
优点:
依赖接口完成可配置可扩展
可配置(不需要修改程序,只需要修改配置文件,程序执行不同的行为)
可扩展(动态增加功能)基础可配置实现(同一个父类或者接口)
弊端:
方法调用时参数溢出也能通过编译
更加耗性能
会跳过编译器,准确性由开发者保障
 
1.1反射的使用(依赖接口):
Assembly assembly = Assembly.Load("TestReflections");//反射的入口 动态加载DLL
Type type = assembly.GetType("TestReflection.DBHelper");//基础类的完整名称找出类
object oDb = Activator.CreateInstance(type);//根据类型,创建对象
IDBHelper IDB = (IDBHelper)oDb;//强转类型
IDB.Query();//使用DLL的方法
 
1.2可配置性的实现:
1.2.1配置文件代码如:
<appSettings>
  <add key="TestReflection" value="TestReflection,TestReflection.DBHelper"/>
</appSettings>
//读取配置文件信息
string nameSpace = ConfigurationManager.AppSettings["TestReflection"];
string[] nameSpaceArr = nameSpace.Split(',');
 
Assembly assembly = Assembly.Load(nameSpaceArr[0]);//反射的入口 动态加载DLL
Type type = assembly.GetType(nameSpaceArr[1]);//基础类的完整名称找出类型
object oDb = Activator.CreateInstance(type);//根据类型,创建对象
IDBHelper IDB = (IDBHelper)oDb;//强转类型
IDB.Query();//使用DLL的方法
 
1.3反射的使用(不依赖接口):
Assembly assembly1 = Assembly.Load(nameSpaceArr[0]);//反射的入口 动态加载DLL
Type type1 = assembly.GetType(nameSpaceArr[1]);//基础类的完整名称找出类型 即类
object oObj = Activator.CreateInstance(type);//创建对象
MethodInfo Query = type.GetMethod("Query");//获取指定方法(type.GetMethods();//获取类的所有方法)
调用方法:
1.3.1无参调用:
Query.Invoke(oObj, null);//第一个参数:方法所在的对象 第二个参数指方法参数,详情见下
 
1.3.2有参数的调用
Query.Invoke(oObj, new object[] { 1, "12" });
 
1.3.3方法重载调用方式
MethodInfo QueryInt = type.GetMethod("Query" , new Type[] { typeof(int) });//通过第二个参数定义获取方法的参数类型,来确定获取的是哪个方法
QueryInt.Invoke(oObj , new object[] { 1 });//调用
 
1.3.4破坏私有函数的规则(.net访问修饰符中的private是只能本类中使用,但是通过反射可以破坏这种机制)
MethodInfo QueryPrivate = type.GetMethod("Query", BindingFlags.Instance | BindingFlags.NonPublic);//获取私有方法
 
1.3.5破坏单例模式(单例模式是指类只能实例化一次,即值进入一次无参构造函数。)(在上例中描述了如果破坏private的机制,在这里讲述如何破坏单例模式,即进入两次无参构造函数)
object oObj2 = Activator.CreateInstance(type2,true);//第二个参数如果公共或非公共默认构造函数可以匹配,则为 true;如果只有公共默认构造函数可以匹配,则为 false。
 
第三节:
1.反射获取属性和赋值
2.封装数据库访问层
 
1)反射获取属性和赋值
           //反射获取属性和赋值
            //1)找到类型 (1.加载DLL 2.找到类型 3.创建对象)
            {
                Type type3 = typeof(DBHelper);//使用typeof()找到类型 前提:知道对象类型
                object obj3 = Activator.CreateInstance(type3);//创建对象
                //type3.GetProperties();    //找出type3类型下的所有属性
                foreach (var item in type3.GetProperties())
                {
                    if (item.Name.Equals("ID"))
                        item.SetValue(obj3, 12);//给属性赋值
                    Console.WriteLine("属性名称:{0},值为{1}", item.Name, item.GetValue(obj3));//获取属性信息
                }
                string fileName = string.Join(",", type3.GetProperties().Select(p => string.Format("[{0}]", p.Name)));//将字符串数组按指定字符连接 返回string类型
            }
 
2)封装数据库访问层
实现思路:
1.通过 类型.Name 获取到模型名称(即表名)
2.通过 类型.GetProperties() 获取到所有的属性名称(即列名)
3.通过 String.Join() 方法拼接列字符串
 
注:
实现数据查询的方法是泛型方法,因为不同的表类型不同,所以在调用的时候需要传入类型(表名)
 
理解:
MVC+EF 使用实体查询是 与这个类似

反射学习:(System.Reflection)的更多相关文章

  1. C#反射发出System.Reflection.Emit学习

    一.System.Reflection.Emit概述 Emit,可以称为发出或者产生.与Emit相关的类基本都存在于System.Reflection.Emit命名空间下.反射,我们可以取得形如程序集 ...

  2. 基础命名空间:反射 using System.Reflection

    反射概念:       .Net的应用程序由几个部分:‘程序集(Assembly)’.‘模块(Module)’.‘类型(class)’组成,程序集包含模块 模块包含类型,类型又包含 成员,而反射提供一 ...

  3. 反射基础 System.Reflection

    一.获取程序集Assembly 1.获取当前运行的程序集 System.Reflection.Assembly[] asm = AppDomain.CurrentDomain.GetAssemblie ...

  4. System.Reflection.Emit学习

    C#反射发出System.Reflection.Emit学习 分享: 1 一.System.Reflection.Emit概述 Emit,可以称为发出或者产生.与Emit相关的类基本都存在于Syste ...

  5. 【C#基础】System.Reflection (反射)

    在使用.NET创建的程序或组件时,元数据(metadata)和代码(code)都存储于"自成一体"的单元中,这个单元称为装配件.我们可以在程序运行期间访问这些信息.在System. ...

  6. C# System.Reflection (反射)

    在使用.NET创建的程序或组件时,元数据(metadata)和代码(code)都存储于“自成一体”的单元中,这个单元称为装配件.我们可以在程序运行期间访问这些信息. 在System.Reflectio ...

  7. 利用.NET Core类库System.Reflection.DispatchProxy实现简易Aop

    背景 Aop即是面向切面编程,众多Aop框架里Castle是最为人所知的,另外还有死去的Spring.NET,当然,.NET Core社区新秀AspectCore在性能与功能上都非常优秀,已经逐渐被社 ...

  8. Java反射学习:深入学习Java反射机制

    一.Java反射的理解(反射是研究框架的基础之一) Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的 ...

  9. Java反射机制(Reflection)

    Java反射机制(Reflection) 一.反射机制是什么 Java反射机制是程序在运行过程中,对于任意一个类都能够知道这个类的所有属性和方法;对于任意一个对象都能够调用它的任意一个方法和属性,这种 ...

  10. 详解反射->Type.System

    反射先了解 一:system.Type 获取基本信息: Type.Name   //类名 Type.FullName //完整路径 Type.Namespace //空间名 public class ...

随机推荐

  1. mac上完整卸载删除.简单粗暴无脑:androidstudio删除方案

    如果你是mac  ,你删除as ,删不干净也正常,你会发现安装的时候,前面的东西也在.配置文件在,会导致你以前的错误不想要的东西都在. 废话不多说,复制粘贴就是干!!!!~~~~~~~~ 第一步: 复 ...

  2. php 生成bing词典能导入的xml(有道词典->bing词典)

    编程以来一直用网易有道词典查单词.翻译:最近一直在看英文方面的资料,于是越来越对有道词典(划词.广告,本来想转灵格斯的,但灵格斯没有android版)不满意,一番试用后决定转bing词典,于是想把有道 ...

  3. perl之创建临时文件夹遇到同名文件该咋办

    当你在目录下进行一系列操作时,若要创建许多文件或者修改文件,可能会遇到许多麻烦的事.所以呢,新建一个文件夹,然后在这个文件夹下新建文件或者修改文件.假设,你的代码要在一个目录下新建一个文件夹,名为Tm ...

  4. 近200篇机器学习&深度学习资料分享【转载】

    编者按:本文收集了百来篇关于机器学习和深度学习的资料,含各种文档,视频,源码等.而且原文也会不定期的更新,望看到文章的朋友能够学到更多. <Brief History of Machine Le ...

  5. Spring Boot2.0之 jar打包方式

    Jar类型打包方式 1.使用mvn celan  package 打包 2.使用java –jar 包名 war类型打包方式 1.使用mvn celan package 打包 2.使用java –ja ...

  6. c语言学习的第13天2

    #include <stdio.h> #include <malloc.h> void f(int **q) { *q=(int *)malloc(sizeof(int)); ...

  7. 分享知识-快乐自己:Hibernate中的 quert.list() 与 quert.iterate() 方法区别

    区别如下: quert.list() : 1):每次都是通过一条语句直接操作数据库取出所有的数据返回(并且将对象存入hibernate缓存中): 2):不会从一二级缓存中查询数据: 3):之执行一条S ...

  8. 勤于思考:IE10不支持检测IE6的代码

    这句话 var isIE6 = isIE && ([/MSIE (\d)\.0/i.exec(navigator.userAgent)][0][1] == 6); 在IE6~9都没问题 ...

  9. EVC入门之二: 在未被加载的DLL中设置断点 (虽然没有遇到这个问题,不过先摘抄下来)

    问题: 这个问题居然也郁闷了我一段时间. 我们假设在EVC里建立了一个project, 里面有SubProject_1(以下简称SB1,嘿嘿), 编译生成一个EXE; SubProject_2(以下简 ...

  10. CodeForces 547E:Mike and Friends(AC自动机+DFS序+主席树)

    What-The-Fatherland is a strange country! All phone numbers there are strings consisting of lowercas ...