- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
(问题在最后)
我对不断更改 FPU 控制字的第三方 COM 组件感到非常头疼。
我的开发环境是Windows和Visual C++ 2008。正常的FPU控制字指定在各种情况下不应该抛出异常。我通过查看 float.h
中的 _CW_DEFAULT
宏以及在启动时查看调试器中的控制字来验证这一点。
每次我调用 COM 对象时,控制字都会在返回时被修改。这很容易防御。我简单地重置了控制字,一切都很好。问题是当 COM 组件开始调用我的事件接收器时。我可以在收到事件调用后立即通过重置控制字来保护我的代码,但是一旦我从事件调用返回,我就无法做任何事情。
我没有这个 COM 组件的源代码,但我正在与作者联系。我从他那里得到的回应是“嗯?”。我不认为他有丝毫线索我在说什么,所以我担心我必须自己做点什么。我相信他的运行时(我认为它是 Delphi 或 Borland C++,因为 DLL 充满了符号名称,全部以大写 T 开头),或者他正在使用的一些其他第三方代码,这导致了问题。我不认为他的代码明确修改了 FPU 控制字。
那么,我能做什么呢?从业务的角度来看,使用这个第三方组件势在必行。从技术角度来看,我可以放弃它,自己实现通信协议(protocol)。然而,这将非常昂贵,因为该协议(protocol)涉及处理信用卡交易。我们不想承担责任。
我迫切需要一个 hack-around,或者一些关于 Borland 产品中 FPU 设置的有用信息,我可以将这些信息传递给组件的作者。
有什么我可以做的吗?我不认为组件作者有能力修复它(从他相当无知的回答来看)。
我一直在考虑安装我自己的异常处理程序,我只是重置了处理程序中的控制字,并告诉 Windows 继续执行。我尝试使用 SetUnhandledExceptionFilter()
安装处理程序,但由于某种原因,未捕获异常。
感谢大家的建议。我已经向作者发送了说明,说明他可以做些什么来让不仅仅是我,还有他的代码的许多其他客户的生活更轻松。我建议他在 DllMain(DLL_PROCESS_ATTACH)
处采样 FPU 控制字,并保存控制字以备后用,这样他就可以在调用我的事件处理程序之前重置 FPU CW,并从我的事件返回电话。
目前,如果有人感兴趣,我有一个 hack-around。变通可能很糟糕,因为我不知道它会对他的 代码做什么。我早些时候收到确认,他没有在他的代码中使用任何 float ,所以这应该是安全的,除非他使用了一些依赖于 FPU 异常的第三方代码。
我对应用所做的两项修改:
WH_CALLWNDPROC
) 以捕获绕过消息泵的极端情况在这两种情况下,我都会检查 FPU CW 是否已更改。如果有,我将其重置为 _CW_DEFAULT
。
最佳答案
我认为您关于该组件是用 Embarcadero 产品编写的诊断很可能是真的。 Delphi 的运行时库确实启用了浮点异常,C++ Builder 也是如此。
Embarcaderos 工具的一大优点是浮点错误会转换为语言异常,这使得数字编码变得更加容易。这对你没什么安慰!
这整个区域是一个巨大的 PITA。没有关于 FP 控制字的任何规则。这是一场完全免费的比赛。
我不认为捕获未处理的异常不会完成工作,因为 MS C++ 运行时可能已经捕获了这些异常,但我不是该领域的专家,我可能是错的。
我相信您唯一现实的解决方案是在执行到达您的代码时将 FPU 设置为您希望的值,并在执行离开您的代码时恢复它。我对 COM 事件接收器知之甚少,无法理解为什么它们会成为执行此操作的障碍。
我的产品包含一个用 Delphi 实现的 DLL,我遇到了相反的问题。大多数调用的客户端都有一个 FPU 控制字来禁用异常。我们采用的策略是在入口处记住8087CW,在执行代码之前将其设置为标准的Delphi CW,然后在导出处恢复。我们也通过在进行回调之前恢复调用者的 8087CW 来处理回调。这是一个普通的 DLL 而不是 COM 对象,因此它可能更简单一些。
如果您决定尝试让 COM 供应商修改他们的代码,那么他们需要调用 Set8087CW()
功能。
但是,由于游戏没有规则,我相信 COM 对象供应商有理由拒绝更改他们的代码并将责任推给您。
如果这不是 100% 的结论性答案,我很抱歉,但我无法将所有这些想法都写进评论中!
关于windows - 第三方代码正在修改 FPU 控制字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6933690/
为什么我可以在控制台 window.window.window.window 中执行此操作并无限追加 .window 并返回 DOM 窗口? 最佳答案 因为 window 对象有一个指向它自身的 wi
Windows管理员用户和系统用户之间有什么权限区别吗? 有些时候,我必须将 cmd 窗口提升到系统权限才能删除一些文件。这可能是因为系统用户锁定了文件,或者系统用户可能具有更高的访问权限,我希望找出
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
Windows 服务和 Windows 进程之间的区别是什么? 最佳答案 服务是真正的 Windows 进程,没有区别。服务的唯一特殊之处在于它由操作系统启动并在单独的 session 中运行。一个独
我有一个 Windows 网络 (peer-2-peer) 以及 Active Directory,我需要记录向服务器发送任何类型打印的用户的名称。我想编写一个程序来记录他们的用户名和/或他们各自的
当我让一个 Windows 服务尝试安装另一个 Windows 服务时遇到问题。 具体来说,我有一个 TeamCity 代理在 Windows 2008 AWS 实例上为我运行测试。这些测试是用 Ja
我创建了一个应用程序来接收广播的 Windows 消息,效果很好。当我把它变成一个服务、安装它并启动服务时,该服务没有收到消息。 最佳答案 服务可能必须被授予访问桌面的权限。从服务属性、“登录”选项卡
我正在使用 Delphi 2010 编写应用程序。我希望在 Windows 启动时启动我的应用程序。我需要它在最新版本的 Windows XP、7.0 和最新的服务器中工作。 将其存储在以下关键工作下
我想开发一个适用于所有三个版本的 Windows XP、Vista 和 7 的应用程序。该应用程序允许人们选择要打开的文件,并允许他们在某些操作后保存文件。三个版本的 Windows 中的每一个都有不
对于\Windows\中的文件类型与\Windows\System32 中的文件类型是否有标准约定? 我正在开发一个 SDK,其中包含各种 DLL、帮助程序 exe 和 Windows 服务 exe。
要求是,必须在 WINDOWS7 机器上配置自动登录,但是这个自动登录应该等待(即延迟)直到另一个 Windows 服务发出继续自动登录的信号。 我使用了自定义凭据提供程序,它在其中等待另一个 Win
很抱歉,这不是一个大问题,而是更多的帮助人们解决这些特定问题的方法。我正在解决的问题要求使用串行I/O,但主要在Windows CE 6.0下运行。但是,最近有人问我是否也可以在Windows下运行该
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
不幸的是 SC 命令在 W2000 上还不可用,所以我不能使用它。 我正在尝试检查服务是否在 W2000 服务器上运行,如果它没有运行,脚本应该能够启动该服务。 如何在 Windows 2000 上执
如何在登录到 Windows 之前启动 Windows 窗体应用程序?是否可以在登录到 Windows 之前启动 Windows 窗体应用程序?如果不是,我是否有机会在登录前启动 Windows 服务
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我想在 XML 文件中区分 Windows XP 和 Windows 7。我想我会在 XML 中为它使用一个环境变量。 但是我找不到在 Windows 中定义的任何系统环境变量来提供此信息。 我看到了
有谁知道我可以在注册表中的哪个位置检查机器上是否安装了这些应用程序: Windows 通讯录 Windows 联系人 最佳答案 来自 Microsoft:我知道它说的是 win 95,但 reg 是一
我正在尝试从我的 Windows 服务器调用放置在远程 Windows 服务器上的批处理文件。我在远程服务器上安装了 freeSSHd。我尝试使用 putty/plink 但没有结果。 我使用的命令语
( 大家好。我是 Windows 编程的新手,所以如果已经有人问过我,我提前道歉,我只是不知道要搜索什么,但这个问题一直让我发疯,我知道有人可能真的很容易回答这个问题。) 我的公司有一个在 Windo
我是一名优秀的程序员,十分优秀!