[解決済み] Excel の相互運用オブジェクトを適切にクリーンアップするにはどうすればよいですか?
質問
C#でExcelのinteropを使っているのですが、(
ApplicationClass
) そして、以下のコードをfinally節に配置しました。
while (System.Runtime.InteropServices.Marshal.ReleaseComObject(excelSheet) != 0) { }
excelSheet = null;
GC.Collect();
GC.WaitForPendingFinalizers();
このように動作するものの
Excel.exe
プロセスは、Excel を閉じた後もバックグラウンドに残っています。このプロセスは、私のアプリケーションを手動で閉じたときにのみ解放されます。
または、相互運用オブジェクトを適切に破棄するための代替手段がありますか?
解決方法は?
アプリケーションがCOMオブジェクトへの参照を保持したままになっているため、Excelが終了しない。
COMオブジェクトの少なくとも1つのメンバーを変数に代入せずに呼び出しているのでしょう。
私の場合、それは excelApp.Worksheets オブジェクトを変数に代入することなく直接使用しました。
Worksheet sheet = excelApp.Worksheets.Open(...);
...
Marshal.ReleaseComObject(sheet);
C#が内部的に ワークシート COMオブジェクトは私のコードでは解放されず(私が気づいていなかったため)、Excelがアンロードされない原因となっていました。
この問題の解決策は このページ また、C#でのCOMオブジェクトの使用に関する素晴らしい規則もあります。
COM オブジェクトにドット 2 つを使用しないでください。
つまり、この知識を持ってすれば、上記の正しい方法は
Worksheets sheets = excelApp.Worksheets; // <-- The important part
Worksheet sheet = sheets.Open(...);
...
Marshal.ReleaseComObject(sheets);
Marshal.ReleaseComObject(sheet);
死後の更新
このHans Passantの回答は、私や他の多くの開発者がつまずいた罠を説明しているので、すべての読者に注意深く読んでほしいです。数年前にこの回答を書いたとき、私はデバッガがガベージコレクタに与える影響について知らなかったので、間違った結論を出してしまったのです。私は歴史のために私の答えをそのままにしていますが、このリンクを読んでください。 ドンマイ 2つの点(quot;the two dots")の道を歩む。 .NETのガベージコレクションを理解する と IDisposableでExcel Interopオブジェクトをクリーンアップする
関連
-
[解決済み】GDI+、JPEG画像をMemoryStreamに変換する際にジェネリックエラーが発生しました。
-
[解決済み】WebForms UnobtrusiveValidationModeは、jqueryのScriptResourceMappingを必要とする
-
[解決済み] エンティティタイプ <type> は、現在のコンテキストのモデルの一部ではありません。
-
[解決済み] 2つのリストを結合する
-
[解決済み] enumを列挙するには
-
[解決済み] intをenumにキャストするにはどうすればよいですか?
-
[解決済み] 辞書を繰り返し使用するには?
-
[解決済み] ディープクローンオブジェクト
-
[解決済み] Microsoft Officeをインストールせずに、C#でExcel(.XLSおよび.XLSX)ファイルを作成するにはどうすればよいですか?
-
[解決済み] Rubyからシェルコマンドを呼び出す方法
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] エンティティタイプ ApplicationUser は、現在のコンテキストのモデルの一部ではありません。
-
[解決済み】プロジェクトビルド時のエラー。エディタでスクリプトにコンパイルエラーがあるため、Playerのビルドにエラーが発生する
-
[解決済み】リソースの読み込みに失敗した:ステータス500(内部サーバーエラー)のサーバーの応答)
-
[解決済み] [Solved] 不正な文字列値: '\xEFxBFxBD' for column
-
[解決済み】Socket.Selectがエラー "An operation was attempted on something that is not a socket" を返す。
-
[解決済み] EntityTypeにキーが定義されていないエラー
-
[解決済み】"指定されたパスのフォーマットはサポートされていません。"
-
[解決済み】Moqを使用してメソッド呼び出しを検証する
-
[解決済み] 関数を終了するには?
-
[解決済み】スレッド終了またはアプリケーションの要求により、I/O操作が中断されました。