トップ «前の日記(2009-05-18) 最新 次の日記(2009-05-20)» 編集

日々の破片

Subscribe with livedoor Reader
著作一覧

2009-05-19

_ NETアプリケーションの最期を看取る

同僚が作ったC#のプログラムが死ぬ。

COMコンポーネントの呼び出しがまずいということはわかっているのだが、とにかく途中でマイクロソフトへ送信するかダイアログが出て、そして何も残らず死ぬ。

こういう状況は以前経験して、そのとき調べた方法をどこかに書いたなぁと裏庭を眺めても出ていない。

で、思い出したが、コーディングの掟の例外の掟のところに書いたのであった。

ハンドルされない例外を受けると規定の動作がMSへの問い合わせとなる。それがいやなら、自分で、ハンドルされない例外ハンドラー(屋上の屋根のような)を設置してやれば良い。ハンドルされない例外ハンドラーはAppDomainが持つので、次のようにする。

AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(
    delegate(object sender, UnhandledExceptionEventArgs e)
    {
        Exception ex = (Exception)e.ExceptionObject;
        using (StreamWriter sw = new StreamWriter(Path.Combine(Path.GetTempPath(), AppDomain.CurrentDomain.FriendlyName + ".Log")))
        {
            sw.WriteLine(ex.Message);
            sw.WriteLine(ex.StackTrace);
        }
        Environment.Exit(1);
     });

というわけで、役に立ったのであった。

コーディングの掟(最強作法) 現場でよく見る不可解なJavaコードを一掃せよ! (開発の現場セレクション)(arton/宇野 るいも)

2003|06|07|08|09|10|11|12|
2004|01|02|03|04|05|06|07|08|09|10|11|12|
2005|01|02|03|04|05|06|07|08|09|10|11|12|
2006|01|02|03|04|05|06|07|08|09|10|11|12|
2007|01|02|03|04|05|06|07|08|09|10|11|12|
2008|01|02|03|04|05|06|07|08|09|10|11|12|
2009|01|02|03|04|05|06|07|08|09|10|11|12|
2010|01|02|03|04|05|06|07|08|09|10|11|12|
2011|01|02|03|04|05|06|07|08|09|10|11|12|
2012|01|02|03|04|05|06|07|08|09|10|11|12|
2013|01|02|03|04|05|06|07|08|09|10|11|12|
2014|01|02|03|04|05|06|07|08|09|10|11|12|
2015|01|02|03|04|05|06|07|08|09|10|11|12|
2016|01|02|03|04|05|06|07|08|09|10|11|12|
2017|01|02|03|04|05|06|07|08|09|10|11|12|
2018|01|02|03|04|05|06|07|08|09|10|11|12|
2019|01|02|03|04|05|06|07|08|09|

ジェズイットを見習え