Совместим ли двоичный код Visual C++ 2017 с VC++ 2015?

Стив говорит мне, что VC 2015 и VC 2017 фактически (будут) двоично-совместимыми.

Я нашел ноль информации по отношению к. это в примечаниях к выпуску на 2017 год (RC) - или почти везде в этом отношении, так что здесь идет:

  • Совместима ли библиотека C++ (интерфейс C++) с бинарным кодом VC++ - 2017 с DLL, созданной с помощью VC++-2015?
  • Используют ли 2017 и 2015 одну и ту же (динамическую) библиотеку времени выполнения?
  • Если да, то какая разница во времени выполнения между Platform Toolset? Visual Studio 2017 (v141) а также Visual Studio 2015 (v140)? (*)

(*): Да, я на самом деле пошел вперед и установил RC 2017, и из того, что я вижу на поверхности, по крайней мере, используется идентичный MSVCRT, то есть msvcp140.dll а также vcruntime140.dll (несмотря на то, что набор инструментов платформы называется "v141".

1 ответ

Решение

Да, библиотеки 141 и 140 практически идентичны. Версия была поднята для параллельной проблемы. Набор инструментов v140 в VisualC++ 2015 и набор инструментов v141 в VC++ 2017 двоично совместимы.

Короче говоря, VC Runtime в MSVC 2017 двоично совместим с 2015

Позвольте мне ответить на ваши вопросы один за другим.

  1. ДА. Оба они будут зависеть от msvcp140.dll и vcruntime140.dll. Если у вас есть библиотека, созданная с помощью набора инструментов платформы v140, этот двоичный файл и ваш код, потребляющий ее, продолжат работать, даже если вы создали свой код с помощью набора инструментов v141 MSVC. Но будьте осторожны, что для любой dll/exe, если какая-то ее часть была построена с помощью набора инструментов v141 MSVC, то окончательный dll / exe должен быть связан с набором инструментов v141 MSVC.
  2. Нет, они имеют одно и то же имя, но они не одинаковы. Dll от VS 2017 новее.
  3. Да. Это различия. Новее, тем лучше.

VCRedist совместим только с обратной совместимостью, поэтому вам нужно будет распространить последний VCRedist, доступный в VS 2017, вместе с вашим приложением. На данный момент, насколько я знаю, вы все еще можете собрать программу к VS 2017, но запустить ее с VC 2015. Но никто не может гарантировать, что это всегда будет работать, потому что команда VS может добавить новые символы экспорта в их среду выполнения VC.

Да, Visual 2019(14.2),2017(14.1),2015(14.0) все бинарно совместимы, все они версии 14.x. Дополнительную информацию см. На https://docs.microsoft.com/en-us/cpp/porting/binary-compat-2015-2017?view=vs-2017. Новые версии добавляют некоторые новые функции или исправления.

Ниже приведены файлы в 2017 и 2019 годах, вы можете найти новые файлы, добавленные в 2019 году.


C:\Users\Liu.D.H>dir "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Redist\MSVC\14.16.27012\x64\Microsoft.VC141.CRT"
 Volume in drive C is System
 Volume Serial Number is 0CAC-076E

 Directory of C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Redist\MSVC\14.16.27012\x64\Microsoft.VC141.CRT

2020-09-25  14:41    <DIR>          .
2020-09-25  14:41    <DIR>          ..
2020-09-25  14:41           332,568 concrt140.dll
2020-09-25  14:41           627,992 msvcp140.dll
2020-09-25  14:41            31,512 msvcp140_1.dll
2020-09-25  14:41           206,104 msvcp140_2.dll
2020-09-25  14:41           366,872 vccorlib140.dll
2020-09-25  14:41            85,784 vcruntime140.dll
               6 File(s)      1,650,832 bytes
               2 Dir(s)  57,822,343,168 bytes free

C:\Users\Liu.D.H>dir "C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Redist\MSVC\14.27.29016\x64\Microsoft.VC142.CRT"
 Volume in drive C is System
 Volume Serial Number is 0CAC-076E

 Directory of C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Redist\MSVC\14.27.29016\x64\Microsoft.VC142.CRT

2020-09-25  13:07    <DIR>          .
2020-09-25  13:07    <DIR>          ..
2020-09-25  13:07           317,224 concrt140.dll
2020-09-25  13:07           590,632 msvcp140.dll
2020-09-25  13:07            31,528 msvcp140_1.dll
2020-09-25  13:07           193,832 msvcp140_2.dll
2020-09-25  13:07            27,936 msvcp140_codecvt_ids.dll
2020-09-25  13:07           337,696 vccorlib140.dll
2020-09-25  13:07           101,672 vcruntime140.dll
2020-09-25  13:07            44,328 vcruntime140_1.dll
               8 File(s)      1,644,848 bytes
               2 Dir(s)  57,822,343,168 bytes free

C:\Users\Liu.D.H>

Потому что я не могу установить файлы 2015 года. Извлекаю (D:\apps\wix311-binaries\dark.exe -nologo -x "D:\tmp\vcredist_x64-2015" "C:\Users\Liu.D.H\Downloads\vc_redist.x64-2015.exe"), и вы можете найти файлы ниже.

liudonghua@desktop-ldh:/mnt/d/tmp/vcredist_x64-2015$ /usr/bin/tree .
.
├── AttachedContainer
│   └── packages
│       ├── Patch
│       │   ├── x64
│       │   │   ├── Windows6.0-KB2999226-x64.msu
│       │   │   ├── Windows6.1-KB2999226-x64.msu
│       │   │   ├── Windows8-RT-KB2999226-x64.msu
│       │   │   └── Windows8.1-KB2999226-x64.msu
│       │   └── x86
│       │       ├── Windows6.0-KB2999226-x86.msu
│       │       ├── Windows6.1-KB2999226-x86.msu
│       │       ├── Windows8-RT-KB2999226-x86.msu
│       │       └── Windows8.1-KB2999226-x86.msu
│       ├── vcRuntimeAdditional_amd64
│       │   ├── cab1
│       │   │   ├── mfc140.dll
│       │   │   ├── mfc140chs.dll
│       │   │   ├── mfc140cht.dll
│       │   │   ├── mfc140deu.dll
│       │   │   ├── mfc140enu.dll
│       │   │   ├── mfc140esn.dll
│       │   │   ├── mfc140fra.dll
│       │   │   ├── mfc140ita.dll
│       │   │   ├── mfc140jpn.dll
│       │   │   ├── mfc140kor.dll
│       │   │   ├── mfc140rus.dll
│       │   │   ├── mfc140u.dll
│       │   │   ├── mfcm140.dll
│       │   │   └── mfcm140u.dll
│       │   ├── cab1.cab
│       │   └── vc_runtimeAdditional_x64.msi
│       └── vcRuntimeMinimum_amd64
│           ├── cab1
│           │   ├── api_ms_win_core_console_l1_1_0.dll
│           │   ├── api_ms_win_core_datetime_l1_1_0.dll
│           │   ├── api_ms_win_core_debug_l1_1_0.dll
│           │   ├── api_ms_win_core_errorhandling_l1_1_0.dll
│           │   ├── api_ms_win_core_file_l1_1_0.dll
│           │   ├── api_ms_win_core_file_l1_2_0.dll
│           │   ├── api_ms_win_core_file_l2_1_0.dll
│           │   ├── api_ms_win_core_handle_l1_1_0.dll
│           │   ├── api_ms_win_core_heap_l1_1_0.dll
│           │   ├── api_ms_win_core_interlocked_l1_1_0.dll
│           │   ├── api_ms_win_core_libraryloader_l1_1_0.dll
│           │   ├── api_ms_win_core_localization_l1_2_0.dll
│           │   ├── api_ms_win_core_memory_l1_1_0.dll
│           │   ├── api_ms_win_core_namedpipe_l1_1_0.dll
│           │   ├── api_ms_win_core_processenvironment_l1_1_0.dll
│           │   ├── api_ms_win_core_processthreads_l1_1_0.dll
│           │   ├── api_ms_win_core_processthreads_l1_1_1.dll
│           │   ├── api_ms_win_core_profile_l1_1_0.dll
│           │   ├── api_ms_win_core_rtlsupport_l1_1_0.dll
│           │   ├── api_ms_win_core_string_l1_1_0.dll
│           │   ├── api_ms_win_core_synch_l1_1_0.dll
│           │   ├── api_ms_win_core_synch_l1_2_0.dll
│           │   ├── api_ms_win_core_sysinfo_l1_1_0.dll
│           │   ├── api_ms_win_core_timezone_l1_1_0.dll
│           │   ├── api_ms_win_core_util_l1_1_0.dll
│           │   ├── api_ms_win_crt_conio_l1_1_0.dll
│           │   ├── api_ms_win_crt_convert_l1_1_0.dll
│           │   ├── api_ms_win_crt_environment_l1_1_0.dll
│           │   ├── api_ms_win_crt_filesystem_l1_1_0.dll
│           │   ├── api_ms_win_crt_heap_l1_1_0.dll
│           │   ├── api_ms_win_crt_locale_l1_1_0.dll
│           │   ├── api_ms_win_crt_math_l1_1_0.dll
│           │   ├── api_ms_win_crt_multibyte_l1_1_0.dll
│           │   ├── api_ms_win_crt_private_l1_1_0.dll
│           │   ├── api_ms_win_crt_process_l1_1_0.dll
│           │   ├── api_ms_win_crt_runtime_l1_1_0.dll
│           │   ├── api_ms_win_crt_stdio_l1_1_0.dll
│           │   ├── api_ms_win_crt_string_l1_1_0.dll
│           │   ├── api_ms_win_crt_time_l1_1_0.dll
│           │   ├── api_ms_win_crt_utility_l1_1_0.dll
│           │   ├── concrt140.dll
│           │   ├── msvcp140.dll
│           │   ├── ucrtbase.dll
│           │   ├── vcamp140.dll
│           │   ├── vccorlib140.dll
│           │   ├── vcomp140.dll
│           │   └── vcruntime140.dll
│           ├── cab1.cab
│           └── vc_runtimeMinimum_x64.msi
└── UX
    ├── 1028
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1029
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1031
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1036
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1040
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1041
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1042
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1045
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1046
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1049
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 1055
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 2052
    │   ├── license.rtf
    │   └── thm.wxl
    ├── 3082
    │   ├── license.rtf
    │   └── thm.wxl
    ├── BootstrapperApplicationData.xml
    ├── license.rtf
    ├── logo.png
    ├── manifest.xml
    ├── thm.wxl
    ├── thm.xml
    └── wixstdba.dll

23 directories, 106 files
liudonghua@desktop-ldh:/mnt/d/tmp/vcredist_x64-2015$

Основные файлы 2015 года следующие.

│           │   ├── concrt140.dll
│           │   ├── msvcp140.dll
│           │   ├── ucrtbase.dll
│           │   ├── vcamp140.dll
│           │   ├── vccorlib140.dll
│           │   ├── vcomp140.dll
│           │   └── vcruntime140.dll

Microsoft постепенно обновляет свои CRT.

Visual C++ 14.0 (2015) CRT имеет 4 файла:

  • vcruntime140.dll (среда выполнения C; от рефакторинга msvcr*.dll)
  • concrt140.dll (среда выполнения с параллелизмом; также из msvcr*.dll)
  • msvcp140.dll (среда выполнения C++)
  • vccorlib140.dll (платформа C++/CX::*)

Visual C++ 14.1 (2017) CRT добавляет только 2 файла:

Visual C++ 14.2 (2019) CRT добавляет только 2 файла:

Если некоторые из дополнительных функций, перечисленных выше, не используются, двоичный файл может работать со старыми версиями C Runtime.

Другие вопросы по тегам