高人求解,关于dll函数调用问题(很奇怪,望高人求解)

一个程序员的修炼之路 2011-08-26 09:45:17
说明下情况:
1. dll依赖关系: 主程序wireshark.exe依赖arinc.dll
wireshark 与 arinc.dll 都依赖mxml.dll (用来解析xml文件)

2. 其中dll均采用 静态链接方式,常用的lib+dll的方式

3. wireshark.exe 与 arinc.dll 均使用 mxml.dll中的两个函数:
p_mxml = mxmlload();
mxmldel(p_mxml); (此处我简写了一些)
p_mxml为建立的数据结构分配了内存;

4. 错误发生了: 程序执行过程首先是 wireshark调用arinc.dll,arinc.dll调用 mxml.dll中的mxmlload()和mxmldel()没有任何问题;
但之后wireshark中直接调用mxmload也没问题,但使用mxmdel()出错!!!出错提示访问冲突!


更奇怪的是我调试程序是没有问题的,直接运行程序才会出错.....(这也是一个重要提示吧,就是调试没问题,直接运行就出错,我已经定位到mxmdel那里了)


忘各位仔细帮我分析下,我会给出大家所需要的提示
...全文
107 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
作为保留问题..... 分先给了..
乔巴好萌 2011-08-26
  • 打赏
  • 举报
回复
你调试看看堆栈
确定是那个dll的问题的话 就try catch掉吧
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 jackyjkchen 的回复:]
有多线程么,有时候多线程调试不会错,运行犯二
[/Quote]
没用到多线程的调用 顺序调用的..
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 xunxun1982 的回复:]
lz可以写个例程么
[/Quote]
可以 今晚没空了 明天写代码测试下。。。
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 openxmpp 的回复:]
我以前调试一个程序 也是调试和运行时 结果不一致
后来发现调试时 加载了一个dll是位于system32下的 和我当前这个dll名字一样 但是版本过旧 导致崩溃
[/Quote]
多谢你的提议,这个方法我也测试过,添加了dll的调试信息,跟踪进去了
乔巴好萌 2011-08-26
  • 打赏
  • 举报
回复
我以前调试一个程序 也是调试和运行时 结果不一致
后来发现调试时 加载了一个dll是位于system32下的 和我当前这个dll名字一样 但是版本过旧 导致崩溃
乔巴好萌 2011-08-26
  • 打赏
  • 举报
回复
有没有可能是你的路径的问题
你调试的时候 路径不但包括你当前的路径的dll 还包括你设置的bin的目录和工作目录的dll
你调试不会出错 那你就仔细看看 你调试时 加载的arinc.dll和mxml.dll 是不是你直接运行的那个目录的dll

jackyjkchen 2011-08-26
  • 打赏
  • 举报
回复
有多线程么,有时候多线程调试不会错,运行犯二
xunxun 2011-08-26
  • 打赏
  • 举报
回复
lz可以写个例程么
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 jackyjkchen 的回复:]
信息太少了,dll或exe的中有bug,只能这么说
[/Quote]

是的 因为调试不会出错 ;
jackyjkchen 2011-08-26
  • 打赏
  • 举报
回复
信息太少了,dll或exe的中有bug,只能这么说
  • 打赏
  • 举报
回复
还有一个提示是,我发现,如果直接运行程序
出错后可以使用vs2005跟踪调试进去,发现错误堆栈处在mxmldel()那里,
p_mxml有一个成员变量为child, child指向空;
但更奇怪的是 我在mxmldel之前打印 p_mxml->child的值到文件里面; 完全不是0;

所以很是奇怪!


但如果我直接调试我的wireshark任何问题都没有,而且跟踪到p_mxml->child是有值得.

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧