国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 辦公 > Excel > 正文

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

2024-08-23 19:47:19
字體:
來源:轉載
供稿:網友

  這段時間在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() ;
  }


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 淄博市| 巴林左旗| 扎囊县| 雷波县| 石柱| 千阳县| 宜良县| 万安县| 锦屏县| 朔州市| 阜南县| 德庆县| 宾阳县| 普宁市| 金坛市| 乌拉特前旗| 辉南县| 卢湾区| 平山县| 马关县| 桐柏县| 阿鲁科尔沁旗| 静安区| 桑植县| 平阳县| 宝丰县| 静宁县| 利辛县| 莆田市| 徐汇区| 东港市| 资兴市| 滁州市| 镶黄旗| 赞皇县| 河源市| 曲靖市| 红河县| 丰镇市| 赣州市| 蓬安县|