我想调试我编写的Windows C ++应用程序,看看为什么它没有响应WM_QUERYENDSESSION我的预期。显然,只需关闭系统就可以做到这一点。是否有任何实用程序或代码可用于向我的应用程序窗口发送假的WM_QUERYENDSESSION?
答案 0 :(得分:1)
我过去曾使用Win32::GuiTest Perl模块来做这类事情。
答案 1 :(得分:1)
Windows API SendMessage可用于执行此操作。 http://msdn.microsoft.com/en-us/library/ms644950(VS.85).aspx
可能它没有响应,因为其他一些正在运行的进程已响应为零(使系统等待它。)
答案 2 :(得分:1)
是的,当然有可能。几个月前我遇到了一个类似的问题,其中一些(未知,但可能是我的)应用程序阻止关机,所以我写了一些快速代码,使用EnumWindows枚举所有顶级窗口,每个窗口发送一条WM_QUERYENDSESSION消息,注意返回什么如果有人返回FALSE,则SendMessage中的值为并且停止枚举。在C ++ / MFC中花了大约十分钟。这是它的内脏:
void CQes_testDlg::OnBtnTest()
{
// enumerate all the top-level windows.
m_ctrl_ListMsgs.ResetContent();
EnumWindows (EnumProc, 0);
}
BOOL CALLBACK EnumProc (HWND hTarget, LPARAM lParam)
{
CString csTitle;
CString csMsg;
CWnd * pWnd = CWnd::FromHandle (hTarget);
BOOL bRetVal = TRUE;
DWORD dwPID;
if (pWnd)
{
pWnd->GetWindowText (csTitle);
if (csTitle.GetLength() == 0)
{
GetWindowThreadProcessId (hTarget, &dwPID);
csTitle.Format ("<PID=%d>", dwPID);
}
if (pWnd->SendMessage (WM_QUERYENDSESSION, 0, ENDSESSION_LOGOFF))
{
csMsg.Format ("window 0x%X (%s) returned TRUE", hTarget, csTitle);
}
else
{
csMsg.Format ("window 0x%X (%s) returned FALSE", hTarget, csTitle);
bRetVal = FALSE;
}
mg_pThis->m_ctrl_ListMsgs.AddString (csMsg);
}
else
{
csMsg.Format ("Unable to resolve HWND 0x%X to a CWnd", hTarget);
mg_pThis->m_ctrl_ListMsgs.AddString (csMsg);
}
return bRetVal;
}
mg_p这只是对话框this指针的本地副本,因此帮助程序回调可以访问它。我告诉过你这很快又脏: - )
答案 3 :(得分:0)
是。如果您可以获得窗口句柄(可能使用FindWindow()),只要WPARAM&amp ;;您可以发送/发送任何消息。 LPARAM不是指针。