我正在将 C++ sdk 从 Windows 移植到 Mac OSX 10.5。我在 Xcode 中有一个问题,我在某些文件中的断点只有在调试时设置它们才会被命中。如果我停止调试然后重新启动,断点将不再受到影响。如果我在不调试时添加它们,它们就不会受到影响。这仅在某些文件中,我的断点总是深蓝色。即我无法区分会被命中的断点和不会被命中的断点。
具体来说,我的sdk由各种动态库组成。这些是使用 Perforce jam 构建的,它根据我的操作系统和编译器版本(例如 Visual Studio 的 cl.exe 和 link.exe)调用各种编译和链接可执行文件。我有一个简单的(单元测试)命令行应用程序,它链接到这些动态库并调用其中的代码。Windows 上的这个应用程序是一个 Visual Studio 项目,我在其中对库代码设置断点并期望它们被命中。
我在 Xcode 3.1.2 中创建了相同的 C++ 命令行实用程序应用程序,它链接到 sdk dylib 并调用其中的代码。一些断点工作正常。我可以在从麻烦的代码中调用的代码中设置断点,然后跳到麻烦的代码,然后我可以很好地单步执行。麻烦的代码被编译到与正常工作的代码相同的dylib中。它也足够长和复杂,不能成为内联的候选者。
我尝试了以下方法:
- 懒惰地关闭加载符号。
- 使用 gcc 4.0 和 gcc 4.2 编译。
- 进行全面清洁并关机。
- 删除 xcodeproj 包的用户特定文件。
- 重命名文件,使它们不会与系统文件冲突。
- 清除断点窗口中的所有内容。
- 创建一个新的 Xcode 项目。
我的应用程序使用 DWARF 格式在调试中编译,并且我的库是使用 -g 标志构建的(以及 -v、-arch i386 和 -fvisibility-inlines-hidden)。
帮助将不胜感激。谢谢。
更新:很抱歉没有更新这个,我的 Mac 端口项目被推迟了。我从来没有解决这个问题,但发现它实际上只发生在构造函数体中。当我再次遇到问题时,我会重新审视这一点。