思维调试:理解 DDE 的初始化过程
创始人
2025-06-29 22:40:33
0

最近有人问我下面这个问题,我们依然可以使用之前我提到的 “思维调试” 来研究研究。

我们碰到了一个技术问题。当在资源管理器中双击打开文档时,资源管理器不会启动我们的应用程序。
更加奇怪的是,如果我们将一个调试器挂接到资源管理器进程,并在 kernel32 模块的 CreateProcessW 处下断点,然后等待 CreateProcess 返回,并在调试器中继续执行,则文档可以正常打开。但是,如果我们不做任何等待,应用程序也可以正常打开,但是它不会加载文档,在这种情况下,我们得到了这样的错误信息:Windows 找不到 ‘abc.lit’。请确保你输入了正确的文档名称,然后重试。
下面是我们使用的命令行:“F:\Program Files\LitSoft\LitWare\LitWare.exe” /dde到底是哪里出了问题呢?

如果你仔细研究过 DDE 初始化的工作原理文章,那么我想你应该已经知道原因了。

回想一下,通过 DDE 打开文档是通过首先查找 DDE 服务器来完成的,如果未找到,则手动启动服务器并重试。上面的命令行显然已注册为与 ddeexec 关联的命令。
我们有两个线索:首先是文档名称本身在命令行上不存在。(这不可能是直接执行,因为程序不知道它应该打开什么文档!但是这条线索是命令行上的短语 /dde。

显然,资源管理器尝试第二个 DDE 对话打开文档时出现问题。让资源管理器等待几秒钟可以解决问题的事实使原因显而易见:DDE 服务器初始化和侦听自身的速度很慢。资源管理器启动服务器并尝试与其通信,但服务器尚未准备就绪,因此不响应 DDE 启动。

如何解决这个问题?

外壳程序假定 DDE 服务器在输入空闲时已准备好接受连接。一旦 DDE 服务器上的 WaitForInputIdle 返回,资源管理器将第二次尝试启动 DDE 会话。此修复程序是让应用程序在开始处理消息之前启动并运行其 DDE 服务器。
我的猜测是应用程序将其 DDE 服务器移动到后台线程以提高启动性能,因为 DDE 服务器不参与正常的程序操作。
但是这太糟糕了,当传递 /dde 标志时,程序忘记在输入空闲之前启动并运行 DDE 服务器。让 DDE 服务器运行很重要,但它错过了正确的时间点。

总结

如果你要实现了一个 DDE 服务器,请确保在主线程开始处理消息之前就启动它。否则,应用程序启动和尝试与之通信的外壳之间存在竞争条件。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...