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

首頁 > 編程 > C# > 正文

解析c#操作excel后關閉excel.exe的方法

2020-01-24 03:12:30
字體:
來源:轉載
供稿:網友
于是提出了kill process的方法,目前我見過的方法多是用進程創建時間篩選excel.exe進程,然后kill 。這樣的方法是不精確的,也是不安全的,通過對網上一些關于Api運用文章的閱讀,我找到了更為直接精確找到這個process并kill的方法
以下就是代碼        
復制代碼 代碼如下:

using   System.Runtime.InteropServices;  

  [DllImport("User32.dll",   CharSet   =   CharSet.Auto)]  
  public   static   extern   int   GetWindowThreadProcessId(IntPtr   hwnd,   out   int   ID);  
  protected   void   Button1_Click(object   sender,   EventArgs   e)  
  {  
      Excel.ApplicationClass   excel   =   new   Microsoft.Office.Interop.Excel.ApplicationClass();  
      excel.Workbooks.Open("d:/aaa.xls",   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing,   Type.Missing);  
      IntPtr   t   =   new   IntPtr(excel.Hwnd);  
      int   k   =   0;  
      GetWindowThreadProcessId(t,   out   k);  
      System.Diagnostics.Process   p   =   System.Diagnostics.Process.GetProcessById(k);  
      p.Kill();                  
   }

以上代碼百分百成功的關閉excel.exe進程
我的做法是結合兩者,先釋放資源,然后關閉進程。
同時網上說避免使用GC.Collect 方法 (),因為會導致整個clr進行gc,影響你的性能.所以我也沒有調用GC.Collect
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长顺县| 彩票| 田东县| 普洱| 永胜县| 和政县| 娄烦县| 河东区| 宁陵县| 潼南县| 开鲁县| 沛县| 承德市| 沙田区| 桓仁| 灵武市| 湖南省| 德安县| 商水县| 宁国市| 兴和县| 武定县| 通许县| 辉南县| 楚雄市| 五峰| 芮城县| 荔波县| 遂宁市| 长子县| 天祝| 邹平县| 城口县| 德州市| 祥云县| 安乡县| 八宿县| 长治县| 苏尼特右旗| 莲花县| 南京市|