设为首页 加入收藏

TOP

代码高处走 从VC6到VC9移植代码问题说明(二)
2014-11-23 20:26:41 】 浏览:1420
Tags:代码 高处 VC6 VC9 移植 问题 说明
ould remove this call.

  e:\software\microsoft visual studio 9.0\vc\atlmfc\include\afxwin.h(4818) : see declaration of 'CWinApp::Enable3dControls'

  通常向导生成的代码是:

  #ifdef _AFXDLL

  Enable3dControls(); // Call this when using MFC in a shared DLL

  #else

  Enable3dControlsStatic(); // Call this when linking to MFC statically

  #endif

  这两个函数的调用是旧的MFC版本对新版本的操作系统特性的支持,在新的(那个时候是新的)Windows 95平台上要这样调用一下才能使用新的Windows 3D样式的控件,否则就是老的Win 3.2样子的控件。想当初喜欢OWL就是因为感觉它的控件比较“酷”,比如那个带底纹的对话框,菱形的checkbox,还有带图标的“OK”按钮,看到MFC作出来的灰灰的界面就觉得土,不过后来就知道MFC做界面也是很漂亮的,比如我做的。。。。,再打住。对于新的MFC版本来说已经不需要再调用这两个函数了,参考前面的方法,用_MSC_VER对其隔离就行了:

  #if _MSC_VER <= 1200 // MFC 6.0 or earlier

  #ifdef _AFXDLL

  Enable3dControls(); // Call this when using MFC in a shared DLL

  #else

  Enable3dControlsStatic(); // Call this when linking to MFC statically

  #endif

  #endif

  五、.def文件引起的连接告警

  对于普通的DLL项目中使用的.def文件通常会引起LNK4017链接告警,如下所示:

  .\ComFunc.def(4) : warning LNK4017: DESCRIPTION statement not supported for the target platform; ignored

  Creating library .\..\Debug/ComFunc.lib and object .\..\Debug/ComFunc.exp

  一个典型的.def文件通常有以下内容:

  LIBRARY "XorCryptor"

  DESCRIPTION 'XorCryptor Windows Dynamic Link Library'

  EXPORTS

  ; Explicit exports can go here

  ..................

  消除这个连接告警的方法就是从.def文件中删除DESCRIPTION描述信息,不过这个告警也不是什么大问题,不删也可以。另一个可能产生的连接告警是LNK4222,通常出现在ocx控件和com组件的项目中,一个典型输出是:

  Linking...

  .\PlusInModule.def : warning LNK4222: exported symbol 'DllCanUnloadNow' should not be assigned an ordinal

  .\PlusInModule.def : warning LNK4222: exported symbol 'DllGetClassObject' should not be assigned an ordinal

  .\PlusInModule.def : warning LNK4222: exported symbol 'DllRegisterServer' should not be assigned an ordinal

  .\PlusInModule.def : warning LNK4222: exported symbol 'DllUnregisterServer' should not be assigned an ordinal

  出现这个告警的原因是旧的项目的.def文件通常这样定义ocx和com必需的四个导出函数:

  EXPORTS

  DllCanUnloadNow @1 PRIVATE

  DllGetClassObject @2 PRIVATE

  DllRegisterServer @3 PRIVATE

  DllUnregisterServer @4 PRIVATE

  其中为这四个重要的导出函数指定了四个顺序号。Windows平台上通常用两种方式定位DLL文件中的导出函数,一种是根据导出函数名称,一种是根据顺序号,上学时曾经写过一个显示图片的程序,能处理大多数当时流行的图像格式文件,唯独jpeg格式的搞不定,有一次看到一个图像处理软件中包含了一个LoadJpeg.dll,很显然这个DLL是处理jpeg格式的图像文件的嘛,于是赶快用depends look了一下,顿时高喊:鬼啊~~~。原来这个depends竟然查不到导出函数的名字,后来才知道还有NONAME参数强制用顺序号定位导出函数,于是就常常弄个没有导出函数名字的DLL到处show。。。。嗯,又扯远了。话说为什么旧的系统要以此指定这四个导出函数的顺序号我就没有研究了,反正现在不需要指定了,只要将@1,@2之类的删除就行了,不过不删好像也没什么问题,它们会被自动忽略。

  六、使用MFC的消息映射宏引起的编译错误

  错误现象之一:

  f:\project\.....\plusmaindlg.cpp(220) : error C2440: 'static_cast' : cannot convert from 'void (__thiscall CPlusMainDlg::* )(int,BOOL)' to 'LRESULT (__thiscall CWnd::* )(WPARAM,LPARAM)'

  None of the functions with this name in scope match the target type

  错误现象之二:

  f:\project\.....\crpfileopavdlg.cpp(87) : error C2440: 'static_cast' : cannot convert from 'LRESULT (__thiscall CCrpFileOpavDlg::* )(LPCTSTR,int)' to 'LRESULT (__thiscall CWnd::* )(WPARAM,LPARAM)'

  None of the functions with this name in scope match the target type

  以上两个编译错误产生是因为新旧版本的MFC 中对ON_MESSAGE消息映射宏定义不同引起的,先看看老版本的MFC的ON_MESSAGE消息宏定义:

  #define ON_MESSAGE(message, memberFxn) \

  { message, 0, 0, 0, AfxSig_lwl, \

  (AFX_PMSG)(AFX_PMSGW)(LRESULT (AFX_MSG_CALL CWnd::*)(WPARAM, LPARAM))&memberFxn },

  再看看新版本的ON_MESSAGE定义:

  #define ON_MESSAGE(message, membe
首页 上一页 1 2 3 4 5 下一页 尾页 2/5/5
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇VC+ADO 连接ACCESS和SQL SERVER的.. 下一篇VC++ 6.0点打开按钮出现 “Micros..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目