最近有人问我下面这个问题,调试我们依然可以使用之前我提到的理解 “思维调试” 来研究研究。 我们碰到了一个技术问题。初始程当在资源管理器中双击打开文档时,化过资源管理器不会启动我们的调试应用程序 。 更加奇怪的理解是 ,如果我们将一个调试器挂接到资源管理器进程,初始程并在 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 服务器 ,请确保在主线程开始处理消息之前就启动它。否则 ,应用程序启动和尝试与之通信的外壳之间存在竞争条件。 |
小新15使用U盘装系统教程(轻松操作,系统安装无忧)你需要了解的15个关键数据中心统计数据如何合理利用闹钟提高生活效率(闹钟的功能和运用技巧)戴尔PowerProtect CyberRecovery保护企业抵御网络安全威胁摩尔线程与浙江华数战略合作:助力“智慧浙江”实现450R5J换屏详细教程(步骤清晰易懂,教你如何更换450R5J的屏幕)用u大侠装系统教程(从购买到安装,一步步教你如何用u大侠装系统)SwatchTouch(探索SwatchTouch的无限可能)iOS启动U盘使用教程(从零开始,轻松掌握iOS启动U盘的使用技巧)电信口碑怎么样?口碑调查揭秘!(电信服务质量、信号覆盖、客户满意度、优惠活动等方面综合评估)源码库云服务器香港物理机亿华云网站建设b2b信息平台企业服务器