AX2009里调用.NET DLL的效率问题
2017-11-15 22:47
190 查看
经常在AX2009里引用.NET的DLL,因为序列化和反序列化,用.NET的定义的实体方便一些,平时数据量不大,也没觉得有什么问题,今天要把几万条数据从数据库中取出来序列化以后,调用第三方系统的接口,发现很慢,开始以为是从数据库里取数慢,于是优化索引,发现没有任何改善。后来把.NET实体调用部分去掉,很快就完成了。
于是在.NET里用C#写了一段代码做测试
上面这一段代码执行只要20-100毫秒的样子,正常范围。
在X++里写一段等效的代码
用了38290毫秒,也就是整整用了38S,搞不懂它在思考什么。
在AX2009里调用.NET类库的效率是让人崩溃的,偶尔数据量小不频繁调用的代码,用用的确蛮方便的,要是数据量大,考虑效率的情况下,还是换个方式吧。。。
于是在.NET里用C#写了一段代码做测试
DateTime startTime = DateTime.Now; POSHelper.POS.GoodsBarcodeList barcodeList = new POSHelper.POS.GoodsBarcodeList(); for (int i = 0; i <= 100000; i++) { POSHelper.POS.GoodsBarcode barcode = new POSHelper.POS.GoodsBarcode(); barcode.Barcode = "111111"; barcode.CName = "111111"; barcode.Code = "111111"; barcode.EAMU = "111111"; barcodeList.Add(barcode); } DateTime endTime = DateTime.Now; MessageBox.Show((endTime - startTime).TotalMilliseconds.ToString());
上面这一段代码执行只要20-100毫秒的样子,正常范围。
在X++里写一段等效的代码
POSHelper.POS.GoodsBarcodeList goodsBarcodeList; POSHelper.POS.GoodsBarcode goodsBarcode; System.DateTime startTime,endTime; System.TimeSpan timeSpan; int i; ; new InteropPermission(InteropKind::ClrInterop).assert(); goodsBarcodeList = new POSHelper.POS.GoodsBarcodeList(); startTime = System.DateTime::get_Now(); goodsBarcodeList = new POSHelper.POS.GoodsBarcodeList(); for(i=1;i<=100000;i++) { goodsBarcode = new POSHelper.POS.GoodsBarcode(); goodsBarcode.set_Barcode("1111111"); goodsBarcode.set_CName("1111111"); goodsBarcode.set_Code("1111111"); goodsBarcode.set_EAMU("1111111"); goodsBarcodeList.Add(goodsBarcode); } endTime = System.DateTime::get_Now(); CodeAccessPermission::revertAssert(); timeSpan = System.DateTime::op_Subtraction(endTime,startTime); print timeSpan.get_TotalMilliseconds(); pause;
用了38290毫秒,也就是整整用了38S,搞不懂它在思考什么。
在AX2009里调用.NET类库的效率是让人崩溃的,偶尔数据量小不频繁调用的代码,用用的确蛮方便的,要是数据量大,考虑效率的情况下,还是换个方式吧。。。
相关文章推荐
- 续:Java Tomcat 中调用.net DLL的方法 - 实际部署中遇到的一些问题解决
- .net中调用VC6生成的dll问题之操作系统无法运行
- VS2010C#调用C++ dll关于.Net版本问题
- .Net利用反射调用DLL时,被调用DLL引用其它库问题
- .Net利用反射调用DLL时,被调用DLL引用其它库问题
- 在.net C#里调用非托管动态库函数dll(转)
- .net调用DLL
- java调用CC++编写的DLL文件问题
- dll调用中的一个小问题
- vb.net 调用Delphi dll问题
- PB调用DELPHI的DLL之间传值的问题,大家来看看
- .net调用vc++写的dll
- [原创]如何在Delphi中调用.Net编写的DLL中的函数(Function)、过程(Procedure)
- 第二十三节: EF性能篇(三)之基于开源组件 Z.EntityFrameWork.Plus.EF6解决EF性能问题 第四节:一些指令总结 定时调度系列之Quartz.Net详解 第十七节:易混淆的概念(静态和非静态、拆箱和装箱) 那些年我们一起追逐的多线程(Thread、ThreadPool、委托异步调用、Task/TaskFactory、Parallerl、async和await)
- .net中前台javascript与后台c#函数相互调用问题
- 关于使用vc++调用matlab生成的dll传递数组的问题
- 在控制台环境下调用MFC DLL崩溃的问题小结
- .net 4.0下发布程序,xp系统提示sqlite.dll需要依赖库问题
- C#调用C++DLL库常见问题
- eclipse调试java调用matlab程序的7.17dll找不到的问题