欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

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

更新时间: 2014-01-05 01:58:15 责任编辑: Author_N1

 

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

[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毫秒
这到底是为什么?不是说反射很慢吗?
--参考方法--
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 01:58:15
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/3851/
本文WWW.DOC100.NET DOC100.NET版权所有。