惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Cisco Talos Blog
Cisco Talos Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Vercel News
Vercel News
B
Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
S
Schneier on Security
Blog — PlanetScale
Blog — PlanetScale
Google DeepMind News
Google DeepMind News
博客园 - 司徒正美
NISL@THU
NISL@THU
T
Threat Research - Cisco Blogs
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Latest news
Latest news
H
Help Net Security
雷峰网
雷峰网
Spread Privacy
Spread Privacy
Cyberwarzone
Cyberwarzone
Project Zero
Project Zero
Security Latest
Security Latest
Know Your Adversary
Know Your Adversary
人人都是产品经理
人人都是产品经理
P
Privacy & Cybersecurity Law Blog
M
MIT News - Artificial intelligence
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
P
Proofpoint News Feed
U
Unit 42
大猫的无限游戏
大猫的无限游戏
A
Arctic Wolf
博客园 - 三生石上(FineUI控件)
Stack Overflow Blog
Stack Overflow Blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
C
Cybersecurity and Infrastructure Security Agency CISA
量子位
C
Cyber Attacks, Cyber Crime and Cyber Security
S
Securelist
S
Security @ Cisco Blogs
T
Threatpost
P
Palo Alto Networks Blog
C
Check Point Blog
V
Vulnerabilities – Threatpost
T
Tailwind CSS Blog
B
Blog RSS Feed
Recorded Future
Recorded Future
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
W
WeLiveSecurity
P
Proofpoint News Feed
P
Privacy International News Feed
AWS News Blog
AWS News Blog
博客园 - 叶小钗
WordPress大学
WordPress大学

博客园 - 廖勇军

关于c++的头文件依赖 增强资源管理器右键功能,含源代码 VC中结构体的内存布局 进程间共享句柄三种方式 SocanCode连接Oracle的方法 SocanCode7之模板编写 javascript总结 IIS7.0中使用MVC3,静态页正常,其它404 ashx的使用 一起来灭掉IE6! iis express感觉还不错 关于sqlite使用entity framework的布署问题 - 廖勇军 - 博客园 负margin实现div的左右排版 原来Jquery.load的方法可以一直load下去 错误1067进程意外终止 关于省市联动的问题想法 javac编译多个带package文件 远程服务器返回了错误 NOTFOUND Java程序放到Linux上出现的问题
不用再纠结反射影响效率了
廖勇军 · 2012-08-03 · via 博客园 - 廖勇军

对于网上流传的“反射效率低”的说法,本人一直是相信的,这是动态和静态的区别,但反射到底影响多大程序一直没测试过,今天本着求是的态度做了个测试

using System;
using System.Diagnostics;
using System.Reflection;

class Program4
{
    static void Main()
    {
        Assembly assembly = Assembly.GetExecutingAssembly();
        Module[] modules = assembly.GetModules(false);
        Type type = assembly.GetType("ThreadClass");
        MethodInfo mi = type.GetMethod("test");

        Stopwatch watch = new Stopwatch();
        watch.Start();
        for (int i = 0; i < 10000; i++)
        {
            ThreadClass.test();
        }
        watch.Stop();
        Console.WriteLine(watch.ElapsedTicks);

        watch.Restart();
        for (int i = 0; i < 10000; i++)
        {
            mi.Invoke(null, null);
        }
        watch.Stop();
        Console.WriteLine(watch.ElapsedTicks);

        Console.Read();
    }
}

class ThreadClass
{
    public static void test()
    {
        //nothing
    }
}

要调用的方法里什么都不做,这样能更好地显示出“纯粹调用”的差距,结果打印:

772
9345

从结果上来看,不到10000个ticks(10000个ticks相当于1毫秒),这说明纯粹的调用差别,一万次以上才会有一毫秒的误差,够小了吧,假设调用的方法里再做点事,这点差别根本忽略不计。

这里要注意的是:调用之前已经获取到了MethodInfo,也许反射最大的性能问题应该在“加载程序集、获取类、获取方法信息”上,因此程序中只要在第一次调用时获取到MethodInfo,以后直接使用,根本没有什么效率的问题可以担心的,除非你傻到每次调用时都做“加载程序集、获取类、获取方法信息”这一系列动作。

总结:只要提前获取到MethodInfo(确切的说是第一次,之后直接使用),10000次以上的调用才有1毫秒的误差,根本不存在效率的担心,放心地使用反射吧!