读书人

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

发布时间: 2013-06-26 14:29:32 作者: rapoo

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


[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的内部机制,那他就未必比你一次反射更划算

读书人网 >高性能WEB开发

热点推荐