熱線電話:13121318867

登錄
首頁精彩閱讀Excel在.Net下駐留內存的解決方法
Excel在.Net下駐留內存的解決方法
2016-01-03
收藏

Excel在.Net下駐留內存的解決方法

這段時間在VS 2003 的WebForm 方式下對Excel 進行操作,遇到一個最為頭疼的問題就是對Excel操作完畢后Excel不能夠正常關閉,系統退出后,Excel總是駐留在內存中。但是這段代碼放到WinForm的程序中又沒有問題。在網上進行了查找也沒有找到有效可行的辦法。經過無數次的嘗試,終于解決如下:

  原來書寫如下:

以下是引用片段:
  private Excel.Application m_app; 
  private Excel.Workbook m_workbook; 
  this.m_app = new Excel.ApplicationClass(); 
  this.m_app.DisplayAlerts = false; 
  this.m_workbook = this.m_app.Workbooks.Open(sFilePath, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value );

  修改后如下:

以下是引用片段:
  private Excel.Application m_app; 
  private Excel.Workbooks m_workbooks; 
  private Excel.Workbook m_workbook; 
  this.m_app = new Excel.ApplicationClass(); 
  this.m_app.DisplayAlerts = false; 
  m_workbooks = this.m_app.Workbooks; 
  this.m_workbook = this.m_workbooks.Open(sFilePath, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value, Missing.Value, Missing.Value, 
  Missing.Value );

  同樣對Sheet的操作如下

  修改前如下:

以下是引用片段:
  Excel._Worksheet worksheet1 = null; 
  worksheet1 = (Excel._Worksheet) this.m_workbook.Worksheets.get_Item(sSheetName); 
  修改后如下: 
  Excel.Sheets sheets = null ; 
  Excel._Worksheet worksheet1 = null; 
  sheets = this.m_workbook.Worksheets; 
  worksheet1 = (Excel._Worksheet) sheets.get_Item(sSheetName);

  發現區別了么?原來Workbooks,Worksheets這兩個類沒有被實例化就直接使用了,造成該類不能夠被回收。最終造成Excel在內存的駐留。

  最終以如下方式釋放。

以下是引用片段:
  private void ReleaseAllRef(Object obj) 
  { 
  try 
  { 
  if (obj != null ) 
  { 
  while (Marshal.ReleaseComObject(obj) > 1); 
  } 
  } 
  finally 
  { 
  obj = null; 
  } 
  } 
  private void Release() 
  { 
  if (m_app != null ) 
  { 
  m_app.Quit() ; 
  } 
  ReleaseAllRef(m_workbook) ; 
  m_workbook = null ; 
  ReleaseAllRef(m_workbooks) ; 
  m_workbooks = null ; 
  ReleaseAllRef(m_app) ; 
  m_app = null ; 
  System.GC.Collect() ; 
  }

數據分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數據分析師資訊
更多

OK
客服在線
立即咨詢
日韩人妻系列无码专区视频,先锋高清无码,无码免费视欧非,国精产品一区一区三区无码
客服在線
立即咨詢