Form.HandleCreated事件永远不会发生

时间:2011-05-13 12:55:47

标签: c# .net winforms nbug

根据要求,我为我的一个开源项目(下面的自描述图片)设置了一个小的内部日志查看器。在这样做时,我遇到了一个非常奇怪的问题,即新创建的窗口的HandleCreated事件根本不会发生。我正在观看此事件以确保在调用任何控件之前创建句柄。

NBug Internal Log Viewer

下面是有问题的代码(静态构造函数)。有没有人为此做一个解决方法,因为强制创建句柄的常用技巧(如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库。

1 个答案:

答案 0 :(得分:2)

问题与static constructor deadlocks有关。