1

リクエストに応じて、オープンソースプロジェクトの1つに小さな内部ログビューアを設置しました(以下のわかりやすい画像)。その間、新しく作成されたウィンドウのHandleCreatedイベントがまったく発生しないという非常に奇妙な問題が発生しました。コントロールを呼び出す前にハンドルが作成されていることを確認するために、このイベントを監視しています。

NBug内部ログビューア

以下は問題のあるコード(静的コンストラクター)です。ハンドルの作成を強制する通常のトリック(var a = form.Handle;など)はまったく役に立たないため、誰かがこれを回避する方法はありますか?

internal partial class InternalLogViewer : Form
{
    static InternalLogViewer()
    {
        viewer = new InternalLogViewer();
        formShown = new ManualResetEvent(false);
        viewer.HandleCreated += (sender, e) => formShown.Set();
        Task.Factory.StartNew(() => viewer.ShowDialog());
        formShown.WaitOne(); // ToDo: This needs a workaround as it waits for an eternity
    }

    private static InternalLogViewer viewer;
    private static ManualResetEvent formShown;

    public static void LogEntry(string message, LoggerCategory category)
    {
        viewer.Invoke((MethodInvoker)delegate
        {
            viewer.InternalLogEntry(message, category);
        });
    }

    internal InternalLogViewer()
    {
        InitializeComponent();
        this.Icon = Properties.Resources.NBug_icon_16;
        this.notifyIcon.Icon = Properties.Resources.NBug_icon_16;
    }

    internal void InternalLogEntry(string message, LoggerCategory category)
    {
        this.loggerListView.Items.Add(new ListViewItem(new[] { category.ToString().Remove(0, 4), DateTime.Now.ToString("HH:mm:ss"), message }));
    }
}

編集:コードはNBugライブラリから取得されます。

4

1 に答える 1

2

この問題は、静的コンストラクターのデッドロックに関連しています。

于 2011-05-14T08:25:24.040 に答える