C#根据反射操作对象
前言
反射使用,让我们的程序可以动态增加一些功能,让原本固化的步骤逻辑变得动态,这是它的优点。当然使用反射首次加载会有性能损耗以及使用复杂;但是现在大家都在讲动态,使用好它应该是一个重要的编程理念提升。MVC、ORM、IOC、AOPA都有使用这个东西了。如果要考虑性能,可以考虑缓存程序集,我们保证程序只加载一次就好。
一、直接利用反射读写对象的值
static void Main(string[] args){Person p = new Person() { Name = "丁竹", Age = 26, Sex = true };p.Working("readinof");//利用反射读取值object obj = p;var type = obj.GetType();foreach (var item in type.GetProperties()){string value = item.GetValue(obj, null).ToString();Console.WriteLine($"{item.Name} {value}");}Assembly ass = Assembly.Load("ReadInfo");object pObj = ass.CreateInstance("ReadInfo.Person");//利用反射设置值{System.Reflection.PropertyInfo propertyInfo = type.GetProperty("Name");propertyInfo.SetValue(obj, "ding", null);}Console.Read();}
二、通过反射调用实例
static void Main(string[] args){//[1].CsharpCodePrivode//提供对C#代码生成器和代码编译器的实例的访问。如果要动态生成VB代码,可以使用VBCodeProvider.//CreateCompiler():获取编译器的实例CSharpCodeProvider objcsharpcodeprivoder = new CSharpCodeProvider();//[2].ICodeComplier//定义用于调用源代码编译的接口或使用指定编译器的CodeDOM树。//每种编译方法都接受编译器的ComplierParameter对象,并返回指示编译结果的CompilerResults对象ICodeCompiler codeCompiler = objcsharpcodeprivoder.CreateCompiler();//[3].ComplierParameters 表示用于调用编译器的参数//ReferencedAssembies:获取当前项目所引用的程序集。Add方法为程序集添加引用//GenerateExecutable:获取或设置一个值,该值指示是否生成可执行文件。若此属性为false,则生成Dll,默认是false.//GenerateInMemor:获取或设置一个值,该值指示是否在内存中生成输出。CompilerParameters objcompilerparameters = new CompilerParameters();// objcompilerparameters.ReferencedAssemblies.Add("System.dll");objcompilerparameters.GenerateExecutable = false;objcompilerparameters.GenerateInMemory = true;//[4].CompilerResults 表示从编译器返回的编译结果//CompiedAssembly:获取或设置以编译的程序集,Assembly类型。CompilerResults cr = codeCompiler.CompileAssemblyFromSource(objcompilerparameters, GenerateCode());if (cr.Errors.HasErrors){Console.WriteLine("编译错误:");foreach (CompilerError item in cr.Errors){Console.WriteLine(item.ErrorText);}}else{//通过反馈,调用HelloWorld实例Assembly assembly = cr.CompiledAssembly;object objHelloWorld = assembly.CreateInstance("DynamicCodeGenerate.HelloWorld");MethodInfo objMI = objHelloWorld.GetType().GetMethod("OutPut");Console.WriteLine(objMI.Invoke(objHelloWorld,null));}Console.ReadLine();}static string GenerateCode(){StringBuilder sb = new StringBuilder();sb.Append("using System;");sb.Append(Environment.NewLine);sb.Append("namespace DynamicCodeGenerate");sb.Append(Environment.NewLine);sb.Append("{");sb.Append(Environment.NewLine);sb.Append(" public class HelloWorld");sb.Append(Environment.NewLine);sb.Append(" {");sb.Append(Environment.NewLine);sb.Append(" public string OutPut()");sb.Append(Environment.NewLine);sb.Append(" {");sb.Append(Environment.NewLine);sb.Append(" return \"Hello world!\";");sb.Append(Environment.NewLine);sb.Append(" }");sb.Append(Environment.NewLine);sb.Append(" }");sb.Append(Environment.NewLine);sb.Append(" }");string code = sb.ToString();Console.WriteLine(code);Console.WriteLine();return code;}
三、通过动态加载Dll生成实例
dom.DoCompileFile(Path.Combine(pathStr, filename), "Test.dll");MySampleDomain = AppDomain.CreateDomain("MySampleDomain");ass = Assembly.LoadFile(AppDomain.CurrentDomain.BaseDirectory + "Test.dll");obj = MySampleDomain.CreateInstanceAndUnwrap(ass.FullName, "Sample.Demo");
四、通过反射调用方法
Type type = obj.GetType();MethodInfo method = type.GetMethod("Add");int a=Convert.ToInt32( method.Invoke(obj, new object[] { 1,3 }));Console.WriteLine(a);
五、完整代码
public class ReflexHelp{public void Execute(string gencode){//[1].CsharpCodePrivode//提供对C#代码生成器和代码编译器的实例的访问。如果要动态生成VB代码,可以使用VBCodeProvider.//CreateCompiler():获取编译器的实例CSharpCodeProvider objcsharpcodeprivoder = new CSharpCodeProvider();//[2].ICodeComplier//定义用于调用源代码编译的接口或使用指定编译器的CodeDOM树。//每种编译方法都接受编译器的ComplierParameter对象,并返回指示编译结果的CompilerResults对象ICodeCompiler codeCompiler = objcsharpcodeprivoder.CreateCompiler();//[3].ComplierParameters 表示用于调用编译器的参数//ReferencedAssembies:获取当前项目所引用的程序集。Add方法为程序集添加引用//GenerateExecutable:获取或设置一个值,该值指示是否生成可执行文件。若此属性为false,则生成Dll,默认是false.//GenerateInMemor:获取或设置一个值,该值指示是否在内存中生成输出。CompilerParameters objcompilerparameters = new CompilerParameters();// objcompilerparameters.ReferencedAssemblies.Add("System.dll");objcompilerparameters.GenerateExecutable = false;objcompilerparameters.GenerateInMemory = true;//[4].CompilerResults 表示从编译器返回的编译结果//CompiedAssembly:获取或设置以编译的程序集,Assembly类型。CompilerResults cr = codeCompiler.CompileAssemblyFromSource(objcompilerparameters, gencode);if (cr.Errors.HasErrors){Console.WriteLine("编译错误:");foreach (CompilerError item in cr.Errors){Console.WriteLine(item.ErrorText);}}else{//通过反馈,调用HelloWorld实例Assembly assembly = cr.CompiledAssembly;object objHelloWorld = assembly.CreateInstance("DynamicCodeGenerate.HelloWorld");MethodInfo objMI = objHelloWorld.GetType().GetMethod("OutPut");Console.WriteLine(objMI.Invoke(objHelloWorld, null));}}public object GenObject(string dllFileName, string typeName){Assembly ass = Assembly.LoadFile(dllFileName);return ass.CreateInstance(typeName);}public int GetAddInfo(object obj, string methrName){Type type = obj.GetType();MethodInfo method = type.GetMethod(methrName);return Convert.ToInt32(method.Invoke(obj, new object[] { 1, 3 }));}/// <summary>/// 编译代码/// </summary>/// <param name="provider">编译器</param>/// <param name="sourceFile">源文件</param>/// <param name="gentenFile">生成文件名</param>/// <returns>编译结果</returns>public CompilerResults CompileCode(CodeDomProvider provider, string sourceFile, string gentenFile){string[] referenceAssemblies = { "System.dll" };CompilerParameters cp = new CompilerParameters(referenceAssemblies, gentenFile, false);cp.GenerateExecutable = false;//设置是否要包含一个入口点CompilerResults cr = provider.CompileAssemblyFromFile(cp, sourceFile);return cr;}}
相关文章:
C#根据反射操作对象
前言 反射使用,让我们的程序可以动态增加一些功能,让原本固化的步骤逻辑变得动态,这是它的优点。当然使用反射首次加载会有性能损耗以及使用复杂;但是现在大家都在讲动态,使用好它应该是一个重要的编程理念提升。MVC、…...
打包python脚本(flask、jinja2)为exe文件
20240803 概述 在我很早时候学习python的时候,就利用过某个工具将其打包为exe文件,然后在没有python环境的机器上运行,这样可以减少安装python环境和各种库的过程。 最近在开发一个在虚拟机上运行的程序的时候就遇到了打包一些环境的问题&…...
嵌入式初学-C语言-练习三
#部分题目可能在之前的博客中有,请谅解,保证常见题型均被发出# 1.计算n以内所有正奇数的和 ? n值通过键盘输入 代码: 1 /*2 需求:计算n以内所有正奇数的和 ? n值通过键盘输入3 */4 #include <stdio.h>5 6 int main()7 …...
最新版Sonible Plugins Bundle v2024 winmac,简单智能,持续更新长期有效
一。Sonible Plugins Bundle v2024 win&mac Sonible Plugins Bundle是一款以创作者为中心的智能音频插件系列。这些工具的特点是易于使用,搭配高级处理和优质音质。pure:bundle的所有插件都由sonible的智能插件系列中使用的技术驱动,但在设计时考虑到…...
J032_实现简易版的B/S架构
一、需求描述 实现简易版的B/S架构 1.1 Server package com.itheima.tcp4;import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.Executors; import java.uti…...
【前端面试】五、框架
目录 1 Vue2 2 Vue3 3 React 4 Angular 1 Vue2 Vue2 是目前仍被广泛使用的前端框架之一,其特点包括响应式数据绑定、组件化开发等。 响应式系统:Vue2 使用 Object.defineProperty 来实现数据的响应式。每个组件实例在创建时,会将 dat…...
C语言 | Leetcode C语言题解之第316题去除重复字母
题目: 题解: char* removeDuplicateLetters(char* s) {int vis[26], num[26];memset(vis, 0, sizeof(vis));memset(num, 0, sizeof(num));int n strlen(s);for (int i 0; i < n; i) {num[s[i] - a];}char* stk malloc(sizeof(char) * 27);int stk…...
本地部署 Llama-3-EvoVLM-JP-v2
本地部署 Llama-3-EvoVLM-JP-v2 0. 引言1. 关于 Llama-3-EvoVLM-JP-v22. 本地部署2-0. 克隆代码2-1. 安装依赖模块2-2. 创建 Web UI2-3.启动 Web UI2-4. 访问 Web UI 0. 引言 Sakana AI 提出了一种称为进化模型合并的方法,并使用该方法创建大规模语言模型ÿ…...
Evaluating the Generation Capabilities of Large Chinese Language Models
文章目录 题目摘要相关工作CG-Eval实验 题目 评估大型中文语言模型的生成能力 论文地址:https://arxiv.org/abs/2308.04823 项目地址:http://cgeval.besteasy.com/ 摘要 本文介绍了 CG-Eval,这是有史以来第一个全面的自动化评估框架…...
YOLOv8添加注意力模块并测试和训练
YOLOv8添加注意力模块并测试和训练 参考bilibili视频 yolov8代码库中写好了注意力模块,但是yolov8的yaml文件中并没用使用它,如下图的通道注意力和空间注意力以及两者的结合CBAM,打开conv.py文件可以看到,其中包含了各种卷积块的…...
「Unity3D」自动布局LayoutElement、ContentSizeFitter、AspectRatioFitter、GridLayoutGroup
布局元素与布局控制器 布局元素实现ILayoutElement接口,布局控制器实现ILayoutController接口,后者根据前者的属性控制具体布局——有些布局控制器也是布局元素,即同时实现这两个接口,如LayoutGroup。 public interface ILayout…...
【Golang 面试 - 进阶题】每日 3 题(十六)
✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/UWz06 📚专栏简介:在这个专栏中,我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏…...
Redis2
为什么Redis要给缓存数据设置过期时间? 内存是有限的,如果缓存中的所有数据都是一直保存,很容易OOM Redis如何判断数据是否过期? 通过过期字典来保存数据的过期时间 过期删除策略 Redis采用的是定期删除惰性删除 Redis内存淘…...
C语言--函数
1. 函数定义 语法: 类型标识符 函数名(形式参数) {函数体代码 } (1)类型标识符 --- 数据类型(函数要带出的结果的类型) 注:数组类型不能做函数返回结果的类型,如果函…...
Shell 编程的高级技巧和实战应用
第一步:高级函数和模块化设计 1.1 高级函数设计 探讨函数的参数处理和默认值设置。示例:实现一个可以处理可选参数的函数。 #!/bin/bashgreet() {local name${1:-"World"} # 如果没有提供参数,使用默认值 "World"ech…...
VMWare虚拟机如何连接U盘
检查配置 1)Win R键,输入services.msc,打开服务。 2)将AMware USB Arbitration Services 服务开启,并设置为自动启动; 连接U盘 目前作者了解有两种连接方式,如有其他连接方式,欢…...
【学习笔记】后缀自动机(SAM)
前言 之前对后缀自动机的理解太浅薄了,故打算重新写一篇。 后缀自动机是什么 后缀自动机是一个字符串的所有后缀建起来的自动机。它把所有子串(后缀的前缀)用 O ( n ) O(n) O(n) 的空间装了起来。后缀自动机的边会构成一个 D A G DAG DA…...
Godot的节点与场景
要深入的理解节点与场景,我们需要跳出这两个概念来看他。说的再直白一些godot本质就是一个场景编辑器! 场景的概念应该在我们平时看电影看电视时会经常提到,比如某一个打斗的场景,这个场景可能会被设在某一个街道,那么…...
C++ 学习(2) ---- std::cout 格式化输出
目录 std::cout 格式化输出简介使用成员函数使用流操作算子 std::cout 格式化输出简介 C 通常使用cout输出数据,和printf()函数相比,cout实现格式化输出数据的方式更加多样化; 一方面,cout 作为 ostream 类的对象,该类…...
前端拿不到Long类型成员变量,用@JsonSerialize(using = ToStringSerializer.class)序列化一下
EqualsAndHashCode(callSuper true) Data TableName("la_school_business") Schema(description "商务负责人表") public class SchoolBusiness extends BaseEntity {private static final long serialVersionUID -7124481085999629236L;/*** 商务负责人…...
技术前沿|AIGC溯源技术全景与应用实践
1. AIGC溯源技术全景:从模型到数据的追踪体系 想象一下,你在画廊看到一幅惊艳的画作,却无法判断它出自人类画家还是AI之手——这正是AIGC溯源技术要解决的核心问题。AIGC(AI生成内容)溯源技术就像数字世界的"指纹…...
P3618 误会
题目大意:给你两个字符串a和b,你可以将a中的与b相同子串替换为*,不限制替换次数(可以为0),问你最多可以替换出多少个不同的字符串。解法:KMP套dp QWQ。先做一遍KMP,再做一次简单dpfor(int i1;i<n;i){//v…...
Flexprice核心组件详解:从计量引擎到发票生成的完整流程
Flexprice核心组件详解:从计量引擎到发票生成的完整流程 【免费下载链接】flexprice 🌟Open source pricing and billing infrastructure to support any pricing model, from usage-based to subscription and everything in between.👨&a…...
【手把手】TEC制冷片从入门到放床底:珀尔帖效应原理、选型与散热避坑指南
文章目录第一章 先别急着买:TEC到底是什么“神仙”元件?1.1 珀尔帖效应:为什么N/P半导体碰一起就会“搬运”热量?1.2 结构拆解:几十对“电偶”是如何叠成一块小方片的?1.3 一条线分清冷热端:别再…...
深度解析:成为一名卓越的民航行业Android开发工程师
在移动互联网深度渗透各行各业的今天,Android作为全球最大的移动操作系统,其开发人才的需求始终旺盛。而特定行业,如民航业(涵盖航务、客运、机场管理等核心领域),由于其业务的复杂性、系统的高可靠性和用户体验的高要求,对Android开发工程师提出了更专业、更严苛的标准…...
GLM-4-9B-Chat-1M实战教程:构建本地AI审计师,自动识别财务报表勾稽异常
GLM-4-9B-Chat-1M实战教程:构建本地AI审计师,自动识别财务报表勾稽异常 1. 项目概述与核心价值 今天我要分享一个特别实用的项目:用GLM-4-9B-Chat-1M大模型搭建一个完全本地的AI审计助手。这个工具能帮你自动分析财务报表,找出那…...
NetBox IPAM实战:如何用Redis提升你的网络管理效率(附详细配置步骤)
NetBox IPAM实战:Redis加速网络管理的全流程指南 在数字化基础设施快速扩张的今天,网络地址管理(IPAM)系统正面临前所未有的性能挑战。NetBox作为开源IPAM领域的标杆工具,其默认配置虽然能满足基础需求,但当遇到大规模网络设备管理…...
5分钟掌握猫抓:网页媒体资源一站式捕获解决方案
5分钟掌握猫抓:网页媒体资源一站式捕获解决方案 【免费下载链接】cat-catch 猫抓 chrome资源嗅探扩展 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓(cat-catch)是一款强大的浏览器资源嗅探扩展,专为解…...
造相Z-Image v2:新手快速部署镜像,体验Turbo模式极速出图
造相Z-Image v2:新手快速部署镜像,体验Turbo模式极速出图 1. 为什么选择造相Z-Image v2? 如果你正在寻找一个既强大又容易上手的AI图像生成工具,造相Z-Image v2绝对值得考虑。这个由阿里通义万相团队开源的文生图模型࿰…...
Python+Selenium自动化:雨课堂智能签到脚本实战
1. 为什么需要雨课堂自动签到脚本? 作为一名大学生,我深刻理解早八课程的痛苦。尤其是冬天早晨,从温暖的被窝里爬起来签到简直是种折磨。更糟的是,有时候明明按时到了教室,却因为网络问题或者操作失误错过签到…...
