2012-03-12 12 views

答えて

2

IDisposableと定義されているオブジェクトを初期化するときは、作成をusingステートメントでラップする必要があります。これは、処分を確実に行うための一般的な規則です。

これには、データコンテキストが含まれます。そうしないと、コントローラがデータコンテキストを使用している間にスローすると、結局オープンな接続になる可能性があります。

3

あなたがEFデータコンテキストについて話しているなら、答えはいいえ、ASP.NET MVCは自動的に処理しませんが、shouldn't be worriedはStephen Waltherがブログ記事で説明したように処理することについて処理します。ここにはsimilar answerがあります。

+1

この議論はどうですか? 「私はIDisposableなものは明示的に破棄すべきだと主張するだろう。クラスをブラックボックスとして扱い、将来のリリースで変更される可能性のある内部実装については仮定しないでください。 – devuxer

+1

これは危険なアドバイスだと思います。原則として、あるタイプが 'IDisposable'を実装している場合、' Dispose'(または 'using'を使用する)を呼び出す必要があると言います。クラスの「公開されている表面」の意図は、あなたが 'Dispose'を呼び出すべきだということです。これがなぜ適用されないのか(なぜなら、あなたがそれを逆コンパイルした、またはチームの開発者の一人に話したため)特権のある情報を知ることは、それをしないかなり不安な理由のようです。たとえば、将来のリリースでこの動作が変更されたらどうなりますか?あなたが特定の理由がない限り、ルールに固執するのは簡単です。 –

関連する問題