通过避免 Activator.CreateInstance 提高 Excel 启动性能
在我们的.Net 应用程序中,Excel 正在运行。有什么方法可以避免在启动 Excel 实例时调用 Activator.CreateInstance()
吗? new Excel.Application()
导致它被调用。
这是打开 Excel 的代码:
public void OpenExcel(string filePath, Action beforeCloseAction, Action beforeSaveAction = null)
{
_excelApp = new Application
{
DisplayAlerts = false,
WindowState = XlWindowState.xlMaximized,
Visible = false,
};
_onBeforeSaveCall = beforeSaveAction;
_excelApp.WorkbookBeforeSave += WorkbookBeforeSave;
_onBeforeCloseCall = beforeCloseAction;
_excelApp.WorkbookBeforeClose += WorkbookBeforeClose;
_excelWorkbooks = _excelApp.Workbooks;
SetExcelWorkbook(_excelWorkbooks.Open(filePath));
_excelWorkbook.Saved = true;
}
In our .Net application, Excel is getting run. Is there any way to avoid calling Activator.CreateInstance()
when starting an Excel instance? new Excel.Application()
causes it to be called.
This is the code which opens excel :
public void OpenExcel(string filePath, Action beforeCloseAction, Action beforeSaveAction = null)
{
_excelApp = new Application
{
DisplayAlerts = false,
WindowState = XlWindowState.xlMaximized,
Visible = false,
};
_onBeforeSaveCall = beforeSaveAction;
_excelApp.WorkbookBeforeSave += WorkbookBeforeSave;
_onBeforeCloseCall = beforeCloseAction;
_excelApp.WorkbookBeforeClose += WorkbookBeforeClose;
_excelWorkbooks = _excelApp.Workbooks;
SetExcelWorkbook(_excelWorkbooks.Open(filePath));
_excelWorkbook.Saved = true;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您是否运行过分析器以便了解性能问题所在?如果对 Activator.CreateInstance 的调用是应用程序中的性能瓶颈,我会感到非常惊讶。据推测,您不会每秒创建许多 Excel 实例,而是在启动时创建一个实例。这是否由 Activator.CreateInstance 完成应该没有什么区别。
Have you run a profiler so that you know where the performance issues lie? I'd be very surprised if the call to Activator.CreateInstance was a performance bottleneck in your application. Presumably you will not be creating many Excel instances per second, but rather one instance on start up. Whether this is done by Activator.CreateInstance or not should make little difference.