请教MFC应用程序为什么真实鼠标点击没有响应,PostMessage模拟消息有响应?

陆人葭 2016-11-30 02:53:57
MFC应用程序在启动后20-30秒内,鼠标左键点击和键盘按键均没有反应,通过GetMessage从消息队列中打印log发现根本没有收到鼠标点击消息,但是WM_TIMER消息可以正常收到;一段时间过后,之前点击的鼠标消息才突然一起发送过来。
我写了一个向这个窗口发送WM_LBUTTONDOWN的程序(PostMessage),当真实鼠标点击没有响应时,发送的消息却可以正常收到(log里有打印)且有响应。
怀疑是鼠标消息被hook了,但是PostMessage不也是把消息放到消息队列里吗?为什么发送的消息就可以收到呢?跟真实的鼠标点击消息有什么区别?还一个怀疑是程序调用的dll里有死循环(消息循环),导致主线程的消息循环被卡住,但是这样的话其他消息为什么可以收到呢?
...全文
375 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
陆人葭 2016-12-02
  • 打赏
  • 举报
回复
引用 7 楼 zhao4zhong1 的回复:
[quote=引用 6 楼 u011646304 的回复:] [quote=引用 5 楼 zhao4zhong1 的回复:] [quote=引用 4 楼 u011646304 的回复:] [quote=引用 3 楼 zhao4zhong1 的回复:] 真实鼠标的按键不灵了。
鼠标按键没有问题,过段时间界面就会对之前的鼠标点击产生反应。[/quote] Windows消息队列快满了或消息循环被别的进程/线程把CPU抢走了。我猜。[/quote] 但是期间其他消息能正常接收,比如WM_TIMER消息和我自己发送过去的WM_LBUTTONDOWN消息,并且界面还能对WM_LBUTTONDOWN做出响应。 是不是由于CPU占用率太高的原因,鼠标驱动没有来得及产生鼠标点击消息放入消息队列?[/quote] 这个你有条件的话倒可以换串口或PS2接口的鼠标试试。我就遇到过USB鼠标反应比PS2鼠标慢的情况。[/quote] 这两种鼠标反应快慢是驱动的区别吗?可能没有条件做这个实验。CPU占用率会不会对消息的产生有影响呢?
赵4老师 2016-12-02
  • 打赏
  • 举报
回复
引用 6 楼 u011646304 的回复:
[quote=引用 5 楼 zhao4zhong1 的回复:] [quote=引用 4 楼 u011646304 的回复:] [quote=引用 3 楼 zhao4zhong1 的回复:] 真实鼠标的按键不灵了。
鼠标按键没有问题,过段时间界面就会对之前的鼠标点击产生反应。[/quote] Windows消息队列快满了或消息循环被别的进程/线程把CPU抢走了。我猜。[/quote] 但是期间其他消息能正常接收,比如WM_TIMER消息和我自己发送过去的WM_LBUTTONDOWN消息,并且界面还能对WM_LBUTTONDOWN做出响应。 是不是由于CPU占用率太高的原因,鼠标驱动没有来得及产生鼠标点击消息放入消息队列?[/quote] 这个你有条件的话倒可以换串口或PS2接口的鼠标试试。我就遇到过USB鼠标反应比PS2鼠标慢的情况。
赵4老师 2016-12-02
  • 打赏
  • 举报
回复
CPU占用率会对消息的产生有影响。我猜。 点击鼠标无响应或响应很慢,十有八九是点击的时候CPU没执行到被点击窗口的消息循环或没及时执行到被点击窗口的消息循环。我觉得。
陆人葭 2016-12-01
  • 打赏
  • 举报
回复
引用 5 楼 zhao4zhong1 的回复:
[quote=引用 4 楼 u011646304 的回复:] [quote=引用 3 楼 zhao4zhong1 的回复:] 真实鼠标的按键不灵了。
鼠标按键没有问题,过段时间界面就会对之前的鼠标点击产生反应。[/quote] Windows消息队列快满了或消息循环被别的进程/线程把CPU抢走了。我猜。[/quote] 但是期间其他消息能正常接收,比如WM_TIMER消息和我自己发送过去的WM_LBUTTONDOWN消息,并且界面还能对WM_LBUTTONDOWN做出响应。 是不是由于CPU占用率太高的原因,鼠标驱动没有来得及产生鼠标点击消息放入消息队列?
赵4老师 2016-12-01
  • 打赏
  • 举报
回复
引用 4 楼 u011646304 的回复:
[quote=引用 3 楼 zhao4zhong1 的回复:] 真实鼠标的按键不灵了。
鼠标按键没有问题,过段时间界面就会对之前的鼠标点击产生反应。[/quote] Windows消息队列快满了或消息循环被别的进程/线程把CPU抢走了。我猜。
陆人葭 2016-12-01
  • 打赏
  • 举报
回复
引用 3 楼 zhao4zhong1 的回复:
真实鼠标的按键不灵了。
鼠标按键没有问题,过段时间界面就会对之前的鼠标点击产生反应。
赵4老师 2016-12-01
  • 打赏
  • 举报
回复
真实鼠标的按键不灵了。
陆人葭 2016-12-01
  • 打赏
  • 举报
回复
引用 1 楼 oyljerry 的回复:
这个是不是当时系统资源比较紧张等,导致鼠标消息没有及时处理,或者换一个试试
那段时间CPU占有率确实比较高,达到99%。但是主线程仍然是可以从消息循环中获取到消息的,比如WM_TIMER和我自己发送过去的WM_LBUTTONDOWN消息,但是真实的鼠标点击就收不到,感觉鼠标点击产生的消息没有进入消息循环,或者因为资源紧张原因,系统根本还没有产生鼠标点击消息。
oyljerry 2016-11-30
  • 打赏
  • 举报
回复
这个是不是当时系统资源比较紧张等,导致鼠标消息没有及时处理,或者换一个试试

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧