- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用单线程 native C++ 应用程序。有一个很难重现的错误,我无法在本地重现。我在发布的可执行文件中启用了整页堆和调试信息,并从客户端获取了转储(它必须使用该应用程序很多天才能获得错误)。
客户端报告的内容:应用程序挂起并且永远无法恢复。它必须从任务管理器中杀死。我从转储中看到:应用程序陷入无限循环。
循环来自遍历一个已经变成循环的双链表。存在内存损坏的迹象,因为许多数据成员具有奇怪的值,例如没有匹配的枚举数、小于 0000FFFF 的值或链表本身的大小被报告为 3 亿以上,这是不正常的。
我可以从转储中获得的唯一其他信息是套接字读取操作失败,读取数据为 0。这会导致(现在是循环的)列表的遍历。
我有几个转储都卡在同一个无限循环中。我试图获取分配堆栈跟踪,但是 !heap -p -a 给了我“地址 eeddccee 的 ReadMemory 错误使用 `!address eeddccee' 检查地址的有效性。”对于我尝试的所有地址。
目前我正在研究修复 L4 警告(除了我不知道哪个可能与此相关,我有一堆 C4100、C4511、C4512,我不知道如何修复;我是主要是修复像 C4244 这样的简单问题)。DebugDiag 没有找到任何东西,除了给我一个“这个线程没有完全解决,可能是也可能不是问题。可能需要对这些线程进行进一步分析。”在单线程上。
据我所知,我的选择是修复更多警告、重新阅读代码直到我突然想到什么或从这里学到新东西。
这真的是内存损坏吗?为什么每次都卡在同一个结构中?我怎样才能找到原因?
最佳答案
修复警告错误是一个好主意——它可能会让你感觉更好,并且肯定会减少构建中的困惑——但它不太可能解决当前的问题,因此最好将其作为带外任务留给 future 。
带有 0 数据的套接字读取失败可能意味着套接字已关闭。也许您在这里遇到了计时问题,其中套接字关闭逻辑导致并发访问某些未正确锁定的共享数据结构。仔细查看套接字代码,确保锁定正确且无懈可击。确保在您的套接字 API 调用中正确处理了所有可能的错误代码(大概是 Winsock?)。您可以确定,即使是容器上并发访问的最小窗口或“不可能发生”的错误路径最终也会在您的生产环境中出现。我知道您说过该应用程序是单线程的,但 Windows 有一个有趣的习惯,它会为您提供并非您自己启动的额外线程,例如,如果您使用的 DLL 服务本身会启动新线程。
当您无法获得良好的生产诊断时会很困难,但如果您可以将问题缩小到特定区域,请尝试在模拟现实生活中使用的单元测试应用程序中隔离失败代码,并强调到底它在您的桌面上。我遇到过这样的间歇性错误,即使在专门测试应用程序的重负载下也需要数小时才能重现该问题。在调试器中以这种模式(当然是发布版本)运行可能会比您想象的更快地暴露问题。
另一种选择可能是安装 Process Dumper在发生故障的机器上并指示它在访问冲突和进程退出时转储完整的内存镜像(根据标准 Windbg DMP 文件可调试)。这可能会提供比小型转储事后调试更好的信息。如果您的客户愿意合作,他们可以指示在下次出现问题时生成转储。这是您无需在机器上或无法远程访问机器即可进行实时调试的最接近方法。
您可能还需要考虑在套接字关闭逻辑中生成额外的诊断,以验证这是否是错误情况的近因。
确保您客户的操作系统和其他系统软件是最新的,并安装了所有必需的补丁。也许这甚至不是你的错(尽管你似乎有一个错误,可以肯定)。
关于c++ - 可能的堆损坏(win 32, native c++),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3684077/
在项目属性窗口的应用程序选项卡和启动对象组合框中,我无法看到我的 win 表单以将其中一个设置为启动对象。 它出什么问题了? 最佳答案 开通 Program.cs启动项目的文件(在解决方案中选择为启动
我的问题是,当我得到正确的数字时,python 脚本结束,但不打印:你赢了! import random number = random.randint(1,100) # This part work
我使用 Eclipse 开发了一个 Java 应用程序。我使用的电脑操作系统是Win Vista。我在 Win XP 计算机上使用此应用程序时遇到问题。我发现的问题是: 如果在我的代码中我使用以下几行
显然,这将打印出石头/剪刀/布获胜或平局。 实现“石头胜剪刀——计算机胜!”这样的结果的最佳方式是什么?等等? var userChoice = prompt("Do you choose rock,
我正在开发一个使用HttpWebRequest将请求发送到另一台服务器的ASP.NET Web应用程序。它通过HTTPS发送请求,并且远程服务器需要客户端证书。该请求在.NET应用程序中失败,显然无法
我正在 WIn XP 上使用 VC6 开发应用程序。使用 GetKeyBoardLayoutList() 和 GetLocalInfo() API 从系统检索默认输入语言列表。 代码如下。 `UINT
我在 WPF 中创建了一个无边框窗口。我已经编写了一个事件来最大化窗口,但是在最大化时,部分窗口有时会隐藏在任务栏后面,片刻之后会出现在任务栏顶部。 如何确保窗口每次都保持在任务栏的顶部?以下是我实现
我开始制作 3d 游戏。然后我停了一段时间并安装了win7。现在我想继续研究它只是为了发现代码卡住了!在 XP 上,我将 View 渲染到窗体上。并且游戏循环和所有游戏形式都在同一个线程上运行! 这在
main() { int *p; free(p); } 此代码在 Win 2K 中崩溃。但不知何故不会在 Win Xp 中崩溃!知道为什么吗? 编辑:是的。这是一个错误,不应该被写入。更多
我在我的应用程序中使用 libeay32.dll/ssleay32.dll 库来支持 https。库在 Windows 7 上成功加载(不是通过我的应用程序,通过 Qt 库),但是我在 Windows
在源代码下方添加了新的详细信息。 有一个问题是 Delphi,其中 Internet 代码可在 Win 10 上运行,但不能在 Win 7 上运行。我正在尝试将一个小项目连接到 haveibeenpw
我在 Win 7 上为 Perfmon 创建了 xml 模板。我能够导入它并运行它 - 一切正常。现在,当我将此 xml 复制到 Win 2008 R2 计算机并尝试将其导入到 perfmon 中时,
我在使用标准数据驱动的 Winform 应用程序时遇到了一个有趣的问题。 该应用程序最初是在 Windows 7 和 Visual Studio 2010 上开发的。然后我用 Windows 8 和
我有一个在 Windows 7(64 位)上编写的程序,可以在我的计算机上正确编译和运行。 但在其他计算机上(特别是在 Windows 8(64 位)上)该程序无法运行。当我尝试运行它时,它说我的程序
将现有的基于 Vb6.0 win 的应用程序转换为基于 c# win 的应用程序的最快方法是什么? 最佳答案 核心语言如此不同,我不得不说从头开始,只复制复杂的代码位。如果您从头开始,您将不必处理所有
我正在处理 IE 11 在 Windows 8 和 Windows 8.1 上的奇怪行为。我正在固定定位元素内的元素位置。而且它变得很奇怪。当我用开发工具检查它时它在正确的位置,但在视觉上它完全在不同
将使用 Java x32 在 eclipse x32 上创建的项目导入到使用 java x64 的 eclipse x64 上有哪些挑战? 最佳答案 Java 是跨平台的,所以你应该不会有任何问题。
鉴于 l 是一个整数列表并且 win 是一个整数,下面的代码生成一个列表 lpadded: lpadded = win // 2 * [-1] + l + win // 2 * [-1] 在 lpad
我有一个适用于 Windows Phone 8.1 的应用程序及其 UWP 版本。我想在 Windows 中更改应用程序的背景时动态更改它。 用例是: 启动应用,背景主题为深色。 按下手机上的主页按钮
不完全确定我是否已经解决了这个问题,但这是我所看到的以及我认为正在发生的事情。 我有一个主要用 C 编写的 Win32 程序,它加载一个 C++ DLL。该 DLL 通过 COM 对象将数据从 C 程
我是一名优秀的程序员,十分优秀!