VS2008无法调用VS2013的dll

一杆走火的枪 2017-03-15 11:18:06
动态库编译环境为VS2013,使用隐式调用,同样的控制台调用程序在VS2012平台上跑完全没有问题,但在VS2008上编译没问题,跑起来的时候会抛异常(std::length_error),请大神帮忙分析下,是还缺少什么东西吗?
...全文
540 19 打赏 收藏 转发到动态 举报
写回复
用AI写文章
19 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2017-03-20
  • 打赏
  • 举报
回复
一杆走火的枪 2017-03-20
  • 打赏
  • 举报
回复
引用 15 楼 zhao4zhong1 的回复:
个人建议:到了万不得已要升级的时候,宁愿在虚拟机中运行旧版,也不升级!
、 谢谢赵老师的建议。问题已经解决,原因是客户提供的dll接口中参数类型有一些类,不是标准C的,在这方面C++98和C++11的规范不一致。现在我重新用VS2013包装了一层,里面的参数不使用类就可以调起来了。
赵4老师 2017-03-17
  • 打赏
  • 举报
回复
个人建议:到了万不得已要升级的时候,宁愿在虚拟机中运行旧版,也不升级!
赵4老师 2017-03-17
  • 打赏
  • 举报
回复
个人建议:不到万不得已,不要升级。
Saleayas 2017-03-17
  • 打赏
  • 举报
回复
使用 .dll 来编译和编译器的版本没有区别。 应该是你的 .dll 和 你自己的程序有 BUG。 仔细调试一下。
一杆走火的枪 2017-03-17
  • 打赏
  • 举报
回复
引用 11 楼 tajon1226 的回复:
[quote=引用 楼主 lizhiqiang12356 的回复:] 动态库编译环境为VS2013,使用隐式调用,同样的控制台调用程序在VS2012平台上跑完全没有问题,但在VS2008上编译没问题,跑起来的时候会抛异常(std::length_error),请大神帮忙分析下,是还缺少什么东西吗?
跨版本IDE,不用动态,还用静态,这不是自找麻烦吗。[/quote] 因为这边要调用类,动态没法调用
走好每一步 2017-03-17
  • 打赏
  • 举报
回复
windows有些动态库是分版本的,某些函数在老版本的库上是没有的。
走好每一步 2017-03-17
  • 打赏
  • 举报
回复
引用 12 楼 lizhiqiang12356 的回复:
[quote=引用 11 楼 tajon1226 的回复:] [quote=引用 楼主 lizhiqiang12356 的回复:] 动态库编译环境为VS2013,使用隐式调用,同样的控制台调用程序在VS2012平台上跑完全没有问题,但在VS2008上编译没问题,跑起来的时候会抛异常(std::length_error),请大神帮忙分析下,是还缺少什么东西吗?
跨版本IDE,不用动态,还用静态,这不是自找麻烦吗。[/quote] 因为这边要调用类,动态没法调用[/quote] 动态可以调的,extend DLL,不过真不建议跨IDE版本。
向立天 2017-03-16
  • 打赏
  • 举报
回复
引用 6 楼 oyljerry 的回复:
不同编译器版本之间调用会存在风险,微软也不建议,最好是用同一个版本编译器编译所有源码,库等,然后调用
对呀,直接把ide升级到2013 现在2017都出了 2008可以被淘汰了
oyljerry 2017-03-16
  • 打赏
  • 举报
回复
不同编译器版本之间调用会存在风险,微软也不建议,最好是用同一个版本编译器编译所有源码,库等,然后调用
赵4老师 2017-03-16
  • 打赏
  • 举报
回复
学会使用depends.exe
xiaohuh421 2017-03-16
  • 打赏
  • 举报
回复
注意依赖库及其版本号
sevancheng 2017-03-16
  • 打赏
  • 举报
回复
动态库编译时使用静态链接MFC库试试
走好每一步 2017-03-16
  • 打赏
  • 举报
回复
引用 楼主 lizhiqiang12356 的回复:
动态库编译环境为VS2013,使用隐式调用,同样的控制台调用程序在VS2012平台上跑完全没有问题,但在VS2008上编译没问题,跑起来的时候会抛异常(std::length_error),请大神帮忙分析下,是还缺少什么东西吗?
跨版本IDE,不用动态,还用静态,这不是自找麻烦吗。
赵4老师 2017-03-16
  • 打赏
  • 举报
回复
崩溃的时候在弹出的对话框按相应按钮进入调试,按Alt+7键查看Call Stack即“调用堆栈”里面从上到下列出的对应从里层到外层的函数调用历史。双击某一行可将光标定位到此次调用的源代码或汇编指令处,看不懂时双击下一行,直到能看懂为止
一杆走火的枪 2017-03-16
  • 打赏
  • 举报
回复
引用 5 楼 zhao4zhong1 的回复:
学会使用depends.exe
用过了,没有找到问题,应该不是依赖的事儿
一杆走火的枪 2017-03-16
  • 打赏
  • 举报
回复
引用 7 楼 xianglitian 的回复:
[quote=引用 6 楼 oyljerry 的回复:] 不同编译器版本之间调用会存在风险,微软也不建议,最好是用同一个版本编译器编译所有源码,库等,然后调用
对呀,直接把ide升级到2013 现在2017都出了 2008可以被淘汰了[/quote] 我也完全理解不了我司为何竟然还在用2008,据说是大家都忙,没时间升级平台。。看来只能让客户将动态库降版本了
一杆走火的枪 2017-03-15
  • 打赏
  • 举报
回复
引用 1 楼 u010165006 的回复:
VS2008默认字符集不是UNICODE?
都是UNICODE
ooolinux 2017-03-15
  • 打赏
  • 举报
回复
VS2008默认字符集不是UNICODE?

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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