VS2017 和 VS2015 应用程序与 dll 之间的官方二进制不兼容性是否准确?

2023-12-13

TL;DR- MS 文档指出 VS2015 和 VS2017 库之间的二进制兼容性是one-way,虽然我认为这必然是双向的。问题在哪里?


首先,背景:

  • 任何 MSVC++ 构建的库都是正式二进制兼容VS2015 和 VS2017 之间。
  • 具体来说,您可以将 VS2015 C++ 应用程序与 2017 年起的 MSVCRT140 版本一起使用。(VCRedist 向后兼容)
  • The 官方文档网站陈述一个令人困惑的限制.

背景/相关问题:

  • Visual-C++-2017 二进制文件与 VC++-2015 兼容吗?
  • 关于“Visual Studio 2015 和 Visual Studio 2017 之间的二进制兼容性”的问题
  • VS2017和VS2015之间的二进制兼容性

我发现令人困惑的限制是:

此规则有两个例外。在这些情况下,不保证二进制兼容性:

...

食用时使用版本更高的工具集构建的库用于编译和链接应用程序的工具集。例如,使用编译器版本 19.12 编译和链接的程序可以使用使用 19.0 到 19.12 编译的库。

恕我直言,这个警告在技术上既草率又令人困惑。技术原因是什么?

我说它很草率,因为它不完整,因为可执行文件和 DLL 之间的接口非常对称,但这个项目符号只涵盖“应用程序”。

具体来说,and假设所有模块都是针对动态 CRT 版本构建的,并且此动态 CRT 版本是可用的最新版本,我看到以下组合,其中二进制兼容性是一个问题:

  • my_2017.exe <-> my_2015.dll——貌似支持
  • my_2015.exe <-> my_2017.dll——貌似不支持
  • my_2017.exe <-> my_2015.dll <-> my_2017_x.dll-- 现在怎么办,这个受支持的 DLL 是在哪个“方向”?

由于二进制兼容 - 纯粹从二进制/接口的角度来看 -必须双向运行,我不太明白我们在哪里突然会遇到不兼容性:API 调用可以双向(回调等),对象“移动”双向,甚至 DLL 加载的顺序也可以混合。

恕我直言,这是很重要的一点,因为它意味着二进制兼容性就像声明的那样 is severly有限的:

  • 如果我的应用程序想要消耗任何VC14*编译库,我“正式”仍然必须确保我的应用程序是使用“最新版本”构建的。
  • 另一方面,如果不构建“应用程序”,但有一个 DLL,我似乎可以使用任何其他应用程序VC14*和DLL可以兼容吗?
  • 有了 VCRedist,我们就有了exactly看似的情况不支持的,即我们是allowed从 2015 年的应用程序使用 VC2017 库(本例中为 CRT)!

Question

那么,为什么(!)会受到这样的限制,以及它与 dll 间依赖关系以及反向(!)CRT-dll 版本要求有何关系。


微软此后更新了他们的文档,当前版本的相关部分https://learn.microsoft.com/en-us/cpp/porting/binary-compat-2015-2017 reads:

Visual Studio 2015 和 Visual Studio 2019 之间的 C++ 二进制兼容性

...

当您混合使用不同受支持版本的 MSVC 工具集构建的二进制文件时, 您的应用程序运行所在的 Visual C++ 可再发行组件不能太旧 比使用的任何工具集版本 构建您的应用程序或其使用的任何库。

差异位于https://github.com/MicrosoftDocs/cpp-docs/commit/a505dccfb31eb49c2ffece4dabd24a0a61b1fcb3#diff-d488b4c71be450b2a39cdce495c229bf

没有直接的 GitHub/MS-Docs 问题,但这个限制更有意义:它只是讨论了兼容性要求可再发行,并且要求 VC 运行时版本至少与正在使用的最新模块一样最新。

当然,这是有道理的,因为这不仅仅是纯粹的二进制兼容性。

当然,我在问题中所说的仍然有效:任何(旧的)VS2015应用程序必须与(新的)VS2019可再发行组件兼容,所以我猜VCRedist-VC14.0曾经公开的所有界面表面都应该是二进制兼容的。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

VS2017 和 VS2015 应用程序与 dll 之间的官方二进制不兼容性是否准确? 的相关文章

随机推荐

  • 重构:从值或现有承诺返回承诺

    我的场景 我曾经有一些node js实施完成使用callbacks但我现在正在重构我的代码以使用Promises相反 使用Q模块 我有以下内容update 函数 其中内部 update 函数已经返回一个Promise exports upd
  • 使用 Java MongoDb 驱动程序进行 Bson 漂亮打印

    我正在使用 Mongo 聚合框架 该框架使用 Java MongoDB 驱动程序版本 3 3 我有一个聚合管道 这只是类型的集合List
  • 将 ctypes 与 jython 一起使用

    我在 python 脚本中使用 ctypes lib 时遇到问题 这是我的代码 在互联网上找到 if name main from ctypes import user32 windll user32 kernel32 windll ker
  • Windows Phone 8.1 Silverlight 和 XAML

    有什么方法可以将 XAML 控件添加到我的 WP 8 1 Silverlight 应用程序中吗 我想使用进度环和切换开关 但似乎 Silverlight 没有它们 我怎样才能添加它们 顺便说一句 添加 使用 Windows UI Xaml
  • 文件夹未推送到 GitHub,仅显示为图标

    我试图添加我的OnlineStore文件夹到GitHub其中有两个主要文件夹 AServerApp and a ClientApp 不知道我做错了什么 ClientApp 文件夹看起来像这样 我什至无法单击它进入内部 这也是它的实际链接 h
  • 为什么gcc使用movl而不是push来传递函数参数?

    注意这段代码 include
  • CSS 边框小于 1px [重复]

    这个问题在这里已经有答案了 可能的重复 HTML 子像素边框 默认border 1px太大了 然而 border 0 5px solid 不管用 有没有一种 CSS 解决方案可以使边框大小减半 像素是渲染物体的最小单位值 但是您可以通过修改
  • sencha touch 消息框不可点击

    在 sencha touch 中 我们在消息框方面遇到了一些问题 看起来是android 4 3的东西 在大多数设备上它都可以完美工作 但在 Android 4 3 的设备上 当用户按下按钮时 消息框不会消失 Ext define Test
  • addChildViewController 实际上做了什么?

    我刚刚第一次涉足 iOS 开发 我要做的第一件事就是实现一个自定义容器视图控制器 我们称之为SideBarViewController 交换它显示的几个可能的子视图控制器中的哪一个 几乎与标准完全相同标签栏控制器 这几乎是一个标签栏控制器但
  • HTML:防止 POST 表单的 url 编码

    我有一个 HTML 表单 必须将其发布到 URL 我希望表单能够发布一个名为 DATA 的变量 如下所示 DATA somevar someval somevar2 someotherval 我在做这件事时遇到了麻烦 看来默认情况下 会对数
  • iOS 的免费语音识别引擎?

    我正在寻找一些免费的语音识别引擎来在我的 iPhone 应用程序中使用 你能推荐吗 Nuance 刚刚为开发人员打开了大门龙移动SDK 他们是行业领导者 看一下NDEV 移动
  • Swift 3.0 和 Xcode 8 迁移后未调用 UITableViewDelegate 方法

    将我的代码库从 Swift 2 2 迁移到 Swift 3 0 后 我注意到我的UITableView页脚没有显示 事实证明我的都没有UITableViewDelegate方法被调用 例如 func tableView tableView
  • 如何从 PHP 解析以文本/xml 形式发送到服务器的 XML?

    我有一个用 jQuery 编写的客户端脚本 它将文本 xml 数据发送到服务器 但我不知道如何解析请求 因为数据不是查询字符串变量 jQuery 看起来像这样 jQuery ajax url test php type POST proce
  • Jetty 9 及更高版本中的 SelectChannelConnector 替代类

    jetty 9及以上版本的SelectChannelConnector的替代类是什么 另外 SelectChannelConnector 类有什么用 连接器类在 jetty servlet 架构中有何用途 我们可以使用 ServerConn
  • Python正则表达式提取日期

    我的字符串看起来像这样 server date YYYYMMDD int server date MON DAY YYYY int 还有更多 不同的日期格式 此外 可以有任意数量的 块 并且它们可以以任意顺序出现 我试图获取 Python
  • 如何通过 Docusign API 将动态图像添加到 Docusign 文档

    我不知道 Docusign API 是否可以实现这一点 但我很好奇是否可以将动态图像添加到模板文档中 此动态图像的目的是根据发送者的身份为文档设置徽标 我知道 Docusign 有品牌 但我们希望此图像位于模板文档的特定位置 如果有人知道这
  • 1 到 100 之间的正则表达式编号

    我搜索了很多 找不到这个 RegExp 的解决方案 我不得不说我在 Reg Expressions 方面不是很有经验 Regex 1 9 0 9 1 100 我想测试一个数字1 到 100 之间 不包括 0 Try 1 9 0 9 100
  • 参数类型可能存在的时间不够长

    我有一个简单的程序 我试图实现多态帐户类型 enum AccountType INVALID TYPE1 TYPE2 trait Account fn get name self gt String fn get type self gt
  • JToken.WriteToAsync 不写入 JsonWriter

    我正在尝试创建一个以某种方式更改请求的中间件 我能够阅读它并更改内容 但我无法弄清楚如何正确设置流编写器来创建新的正文 当我打电话时normalized WriteToAsync jsonWriter the MemoryStream仍然是
  • VS2017 和 VS2015 应用程序与 dll 之间的官方二进制不兼容性是否准确?

    TL DR MS 文档指出 VS2015 和 VS2017 库之间的二进制兼容性是one way 虽然我认为这必然是双向的 问题在哪里 首先 背景 任何 MSVC 构建的库都是正式二进制兼容VS2015 和 VS2017 之间 具体来说 您