首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > 高性能WEB开发 >

反射与直接调用时的性能有关问题

2013-06-26 
反射与直接调用时的性能问题[TestClass]public class UnitTest1{//DbContext DbContext DbContext.GetIn

反射与直接调用时的性能问题


[TestClass]
    public class UnitTest1
    {
        //DbContext DbContext = DbContext.GetInstance("Provider=microsoft.jet.oledb.4.0;data source='d:/wwwroot/wzxinchen/databases/xinchenDB.mdb'", "System.Data.OleDb");
        string method = "GET";

        string[] parameters;

        public string[] Parameters
        {
            get { return parameters; }
            set { parameters = value; }
        }
        ParameterInfo[] pis;

        string controller = "Board";
        string action = "Child";
        string path = "/bbs";
        [TestMethod]
        public void Action()
        {
            BoardController c = new BoardController();
            c.Child(11);
        }
        [TestMethod]
        public void ReflectAction()
        {
            this.parameters = new string[2];
            Controller controller = (Controller)ClassHelper.getClass("Xinchen.WebSite", "Controllers.bbs.BoardController");

            Type controllerType = controller.GetType();
            ControllerContext controllerContext = new ControllerContext(controller, new ControllerValuePair(this.controller, this.action, this.path));
            ControllerContext.Current = controllerContext;
            MethodInfo mi = ClassHelper.GetMethod(controllerType, action);
            ActionResult actionResult = (ActionResult)mi.Invoke(controller, new object[2] { 11, 1 });
        }

    }

以上是测试代码,使用的vs的单元测试
Action方法用了500毫秒
ReflectAction方法居然只用了5毫秒
这到底是为什么?不是说反射很慢吗?
------解决方案--------------------


我想问一下,
Action方法用了500毫秒
ReflectAction方法居然只用了5毫秒
1、你得出这个结论是一次运行结果还是经过多次的统计结果。。。
2、5ms和500ms相差并不明显,不像是5s和50s,可能在你运行程序的时候,cpu在处理其他进程。。。
[解决办法]
可能的解释是BoardController的构造函数比较耗时,而ReflectAction方法的反射和调用有缓存的处理,使得调用可以不用执行对象的构造
[解决办法]
不然的话,就是测试数据有错误或者运行的环境有特殊的地方了,反射需要分析的数据量是很多很多的,耗时是不可否认的。
[解决办法]
在你另外的帖子你已经说了我的态度

至于你这个帖子,俺说是你测试的手段有问题。我不知道
BoardController c = new BoardController();
            c.Child(11);

是怎么写的,看你的参数是mvc的方式,那么你这个BoardController,内部到底依靠的多少asp.net mvc的内部机制俺不得而知。俺只能告诉你,你真以为asp.net mvc是一个很纯粹的东西,asp.net mvc内部其实不知道使用了多少道的反射封装,如果你这个BoardController本身依赖了很多asp.net mvc的内部机制,那他就未必比你一次反射更划算

热点排行