3

我正在尝试关闭基于 CDialog 的应用程序。我调用 CWnd::OnClose() 然后调试器进入 Windows 系统文件。在调试器输出窗口中,我无限期地得到这些循环行。

线程“Win32 线程”(0x1040) 已退出,代码为 0 (0x0)。线程“Win32 线程”(0x2fa4) 已退出,代码为 0 (0x0)。线程“Win32 线程”(0x1ca0) 已退出,代码为 0 (0x0)。'LifescanDatabaseApplication.exe': 卸载'C:\Windows\SysWOW64\davclnt.dll' 'LifescanDatabaseApplication.exe': 卸载'C:\Windows\SysWOW64\davhlpr.dll' 'LifescanDatabaseApplication.exe': 加载'C:\Windows \SysWOW64\davclnt.dll',找不到或打开 PDB 文件 'LifescanDatabaseApplication.exe':已加载 'C:\Windows\SysWOW64\davhlpr.dll',找不到或打开 PDB 文件

有什么想法我打破了或我应该如何追踪它?谢谢,詹姆斯

编辑对话框的函数 OnClose() 显示在这里;

void CApplicationDlg::OnClose()
{
    UpdateData(TRUE);
    if(AfxMessageBox(_T("Are you sure you want to close? If so, no more updates will be issued"),MB_YESNO)==IDYES)
    {
    Logger * instance = Logger::Instance();
    if(instance!=nullptr)
    {
      instance->writeToLogFile("Application shutdown.");
    }
        CWnd::OnClose();
    }
}

我已经通过 Cwnd::OnClose() 命令使用调试器跟踪了这一点。问题是,代码没有回到调用对话框来运行 EndDialog 的部分。我想我在对话框代码的其他地方改变了一些东西,阻止了这个工作。

编辑 2:用 this->EndDialog(0) 替换 CWnd::OnClose() 似乎可以解决问题,但这令人担忧。

4

2 回答 2

1

您应该在http://msdn.microsoft.com/en-us/library/866bc849(v=vs.80).aspx的文档中查看 CWnd::OnClose 。您将看到它是一个响应事件发生而被调用的函数:窗口接收到 WM_CLOSE 消息,指示窗口应该关闭。简单地调用它不会关闭窗口。

您应该使用适当的返回码http://msdn.microsoft.com/en-us/library/wddd3ztw%28v=vs.80%29.aspx调用 EndDialog 。

于 2012-10-23T23:19:39.993 回答
1

真正的问题是按钮上的 id 出现了一些混乱,这意味着正在调用处理程序,导致方法运行需要很长时间才能完成。

解决了这个问题,一切正常。谢谢你的帮助

于 2012-11-02T11:54:46.260 回答