反射实例化类
public class Person
{
public string Name { get; set; }
public Person(string name)
{
this.Name = name;
}
public string Say(string msg)
{
return $"{Name}: {msg}";
}
}
class Program
{
const int count = 10000000;
static void Main(string[] args)
{
CreateInstance0();
CreateInstance1();
CreateInstance2();
CreateInstance3();
CreateInstance4();
Console.Read();
}
static void CreateInstance0()
{
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
Person person = new Person("张三");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - new");
}
static void CreateInstance1()
{
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
object person = Activator.CreateInstance(typeof(Person), "张三");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - Activator.CreateInstance");
}
static void CreateInstance2()
{
Assembly assembly = Assembly.GetExecutingAssembly();
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
Person obj = (Person)assembly.CreateInstance("ConsoleTest.Person", true, BindingFlags.Default, null, new object[] { "张三" }, null, null);
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - Assembly.CreateInstance");
}
static void CreateInstance3()
{
Assembly assembly = Assembly.GetExecutingAssembly();
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
Type type = assembly.GetType("ConsoleTest.Person");
object person = Activator.CreateInstance(type, "张三");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - Assembly.CreateInstance1");
}
static void CreateInstance4()
{
Assembly assembly = Assembly.GetExecutingAssembly();
Stopwatch watch = new Stopwatch();
watch.Start();
Type type = assembly.GetType("ConsoleTest.Person");
for (var i = 0; i < count; i++)
{
object person = Activator.CreateInstance(type, "张三");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - Assembly.CreateInstance2");
}
}

- 通过反射实例化对象,要比直接 new 要慢 50 倍左右
assembly.CreateInstance
要比 Activator.CreateInstance
慢,主要的性能损耗在 Assembly.GetType
反射调用类的方法
class Program
{
const int count = 10000000;
static void Main(string[] args)
{
InvokeMethod0();
InvokeMethod1();
InvokeMethod2();
InvokeMethod3();
InvokeMethod4();
Console.Read();
}
static void InvokeMethod0()
{
Person person = new Person("张三");
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
string name = person.Say("Hello World!");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - 直接调用");
}
static void InvokeMethod1()
{
Person person = (Person)Activator.CreateInstance(typeof(Person), "张三");
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
string name = person.Say("Hello World!");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - 反射缓存类调用");
}
static void InvokeMethod2()
{
Person person = (Person)Activator.CreateInstance(typeof(Person), "张三");
MethodInfo method = typeof(Person).GetMethod(nameof(Person.Say), new Type[] { typeof(string) });
Func<string, string> func = (Func<string, string>)method.CreateDelegate(typeof(Func<string, string>), person);
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
string result = func("Hello World!");
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - 使用反射创建出来的委托调用");
}
static void InvokeMethod3()
{
Person person = (Person)Activator.CreateInstance(typeof(Person), "张三");
MethodInfo method = typeof(Person).GetMethod(nameof(Person.Say), new Type[] { typeof(string) });
object[] parameters = new object[] { "Hello World!" };
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
string name = (string)method.Invoke(person, parameters);
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - 使用反射得到的方法缓存调用");
}
static void InvokeMethod4()
{
Person person = (Person)Activator.CreateInstance(typeof(Person), "张三");
object[] parameters = new object[] { "Hello World!" };
Stopwatch watch = new Stopwatch();
watch.Start();
for (var i = 0; i < count; i++)
{
string result = (string)(typeof(Person).GetMethod(nameof(Person.Say))?.Invoke(person, parameters));
}
watch.Stop();
Console.WriteLine($"{watch.Elapsed} - 直接使用反射调用");
}
}

- 反射得到实例后调用方法和直接调用方法效率一样
- 缓存反射方法调用和直接使用反射调用都非常耗效率
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?