动态链接MFC引发的血案

首先简单描述下程序运行的步骤,

我们要去加载两个DLL,先加载的称为A,后加载的称为B,加载A在里面做的事情是动态创建一个全局对象,加载B在里面做的事情是取得这个全局对象,然后干其他事情。

 

我们机子上运行的非常完美。但在用户的机子上却没法运行。报错直接说这个全局对象为空,并没被初始化。真是奇了怪了。

开始认为我们的加载顺序有问题,查了下代码,没问题!

 

我们把程序放在WIN7下测试,也没问题。后来另一位同事在另个新系统下面测试,BUG重现!然后同事想把Visual Studio装上调试,居然又运行完好。头儿提醒可能是加载A没成功。于是卸载VS,先在A中打上日志,又在加载A之前打上日志,一看,发现果然是这个问题!!

 

但为啥会加载失败呢?用depends查看A有两个依赖的dll未知!另外还有个帮忙的同事提醒说,加载失败,可能是由于清单文件所依赖的组件在新安的系统并没有。一看清单*.mainifest文件,果然如此,多了两个外来的动态依赖库,

 

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
  <dependency>
    <dependentAssembly>
      <assemblyIdentity type="win32" name="Microsoft.VC80.DebugCRT" version="8.0.50727.762" processorArchitecture="x86" publicKeyToken="1fc8b3b9a1e18e3b"></assemblyIdentity>
    </dependentAssembly>
  </dependency>
  <dependency>
    <dependentAssembly>
      <assemblyIdentity type="win32" name="Microsoft.VC80.DebugMFC" version="8.0.50727.762" processorArchitecture="x86" publicKeyToken="1fc8b3b9a1e18e3b"></assemblyIdentity>
    </dependentAssembly>
  </dependency>
</assembly>

但转念一想,不对啊,B都没这两个外来组件引入的清单,A怎么多了这两个东西!

将A和B对比编译配置,完全相同,百思不得其解!

 

帮忙的同事又说,A所依赖的我们项目中的dll会不会有动态库?一查,果然如此,另一个的编译选项居然是Use MFC in a share dll!照理说应该编译过不了,但可爱的同事用忽略库的办法将其编译错误去掉,于是导致A生成的清单文件上会出现上述内容。

 

 

应该说,粗心是不可避免的。

但有几点需要以后注意的:

1. 捕获异常措施不够,是其本质原因。

2. 测试环境需要真正模拟玩家环境。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/499651.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

规避软件架构风险之反模式

在QCON大会上&#xff0c;Michael Nygard&#xff0c;以及 李伟专家都提到了一个概念&#xff0c;容错能力。 衡量软件架构最佳的一个很重要的因素就是看软件的容错能力。没有容错能力的软件&#xff0c;哪怕你QA都非常优秀&#xff0c;但一发生故障就出现集联失效&#xff0c;…

使用DC

timer里面尽量避免使用DC&#xff0c;不然会非常慢

wxPython做界面的适用性

wxpython 优点&#xff1a; 1. 提高了程序的可维护性 2. 界面布局可由专业人员设计 3. 更好的支持GUI布局设计工具 4. 作为wxWidgets的规范&#xff0c;XRC资源可通用于C、Python等语言 5. PYTHON脚本语言上手很快。 6. 分离界面布局和程序逻辑 7. 跨平台 缺点&…

ODBG常用快捷键总结

CtrlN 输入表查看。一般在没加壳的程序中能够解析出来。实践过程中&#xff0c;可快速定位到一些常用API&#xff0c;然后将其作为突破口。 AltM 内存查看。能快速定位不同模块的区段&#xff0c;能够设置某个模块的访问断点。 Alt<- 看见高手操作&#xff0c;能直接恢…

wPython环境安装

http://laochake.javaeye.com/blog/438667 关于版本问题&#xff0c;还是用最新最稳定就行。

__declspec(naked)和__asm编写实践总结

__cdecl 和 __stdcall 压栈参数顺序是一致的&#xff0c;但平衡堆栈方式不一样。 __cdecl调用函数方式是调用者&#xff0c;即函数外部平衡堆栈&#xff0c;一般是在函数外部调用add esp, xxxx&#xff0c;函数内部只需要ret返回就行 __stdcall调用函数方式是被调用&#xff…

逆向调试雷电思路总结

1.首先根据内存变化&#xff0c;能迅速找到飞机的生命&#xff0c;炸弹&#xff0c;分数&#xff0c;能够基本确认飞机结构。 2.找飞机位置有点困难&#xff0c;但可以查找飞机结构属性周围的内存变化找到飞机变化的坐标&#xff0c;这里有个小技巧&#xff0c;可以将内存十六进…

共享内存实践总结

经过实验得之&#xff0c;共享内存只有在两个进程同时存在的情况下映射才会成功 。 当共享内存在一个进程映射的情况下&#xff0c;此进程一旦销毁&#xff0c;共享内存即刻销毁,当第二个进程创建共享内存&#xff0c;会有新的共享内存空间。 另外console进程&#xff0c;在mai…

调试总结

1.调试程序之前不要放过每个细节&#xff0c;包括资源配置文件的所有东西都必须过一道两道或者三道&#xff0c;在这里发现的线索往往能让你调试事半功倍。 2.解析收包发包是基础&#xff0c;往往能跟到比较有价值的线索。 3.找结构体指针地址&#xff0c;想通过内存搜索来找…

sizeof

对于new出来的array sizeof()得到的只是指针大小 对于直接赋值的array sizeof()得到的就是整个数组的大小 memcpy的时候特别注意

关于栈实践总结

今天发了个帖&#xff0c;问栈位于进程空间的哪个位置&#xff0c;居然很多人都不清楚。本人用OD看了下就一目了然 进程结构示意图&#xff1a; 主线程堆栈 --临时变量都在里面主线程pe --GetModuleHandle(NULL)通过API得到的进程首地址在这个位置&#xff…

中文路径

混合编码编译选项不能读中文路径 需要设置为unicode编译选项wifstream ifs; ifs.read(参数1&#xff0c;参数2) 参数2传的是个数&#xff0c;跟Unnicode无关将参数1转化成ansic过后得到的string.size()跟参数2不一样。 所以取读取的长度还是用参数2PS: string.size()跟string.l…

通过VirtualQuery获取当前模块的句柄

HMODULE ModuleFromAddress( PVOID pv ){MEMORY_BASIC_INFORMATION mbi;if(::VirtualQuery(pv, &mbi, sizeof(mbi)) ! 0){return (HMODULE)mbi.AllocationBase;}else{return NULL;}} 得到的模块基地址HMOUDULE handle ModuleFromAddress((PBYTE)ModuleFromAddress)就是模块…

D3DLOCK写纹理遇到的问题

现象&#xff1a;以D3D_DISCARD方式来LockRect写入的显存数据在UnLock过后拷贝出来就崩溃&#xff0c;在一些机器出现而在某些机器就不会出现。 解决&#xff1a;判断游戏写纹理数据LockRect方式是D3D_DISCARD的话&#xff0c;在UnLockRect写完数据过后&#xff0c;就不对原来显…

去除ring3层的Debug标志

_asm{mov eax, fs:[0x18]mov eax, [eax0x30]mov dword ptr ds:[eax],0}

2011工作总结

1、编码能力 代码实践中&#xff0c;开始注重模型的概念。所谓模型打个比方&#xff1a;要做一台电视机&#xff0c;首先搞清楚你想怎么使用它&#xff0c;目的是让它看起来更方便易用。根据常规经验判断&#xff0c;电器需要电源、需要信号&#xff0c;这两点是必不可少。OK&a…

逆向调试完成端口回包实践总结

大概描述下完成端口的原理 一个套接字可以对应多个overlapped, 每个overlapped都由相应的一个线程来处理。而WSARecv绑定好了一个OVERLAPPED&#xff0c;WSARecv的调用会通知数据即将到来&#xff0c;同时将会触发某线程中的GetQueuedCompletionStatus函数调用完成&#xff0c;…

编码问题

从XML读进来的UTF8编码需要转一次到宽字符&#xff0c;宽字符再转化成窄字符。 在中文系统下面读中文&#xff0c;没问题。 但读韩文的时候&#xff0c;第二步就会出现丢失现象。 所以在国际化中&#xff0c;最好都统一用宽字符编码

zeromq

使用zeromq注意context是多个socket的集合。 频繁删除创建context会产生异常&#xff0c;估计是zeromq的bug&#xff0c;待分析

静态添加DLL

LordPE 这个工具能够直接静态添加DLL,这下更方便了具体步骤&#xff1a;1. 点击PE编辑器&#xff0c;打开要添加的exe2. 进入目录表&#xff0c;选择输入表一项&#xff0c;点击省略号3..进入添加DLL界面。选择要添加的DLL。dll必须有一个导出函数添加即可,最后保存