Совместим ли двоичный код 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
Позвольте мне ответить на ваши вопросы один за другим.
- ДА. Оба они будут зависеть от msvcp140.dll и vcruntime140.dll. Если у вас есть библиотека, созданная с помощью набора инструментов платформы v140, этот двоичный файл и ваш код, потребляющий ее, продолжат работать, даже если вы создали свой код с помощью набора инструментов v141 MSVC. Но будьте осторожны, что для любой dll/exe, если какая-то ее часть была построена с помощью набора инструментов v141 MSVC, то окончательный dll / exe должен быть связан с набором инструментов v141 MSVC.
- Нет, они имеют одно и то же имя, но они не одинаковы. Dll от VS 2017 новее.
- Да. Это различия. Новее, тем лучше.
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 файла:
- vcruntime140_1.dll (похоже, патч для SEH в vcruntime140.dll)
- msvcp140_1.dll ( ресурсы полиморфной памяти C++17)
Visual C++ 14.2 (2019) CRT добавляет только 2 файла:
- msvcp140_2.dll ( специальные математические функции C++17 и std::hypot(x, y, z))
- msvcp140_codecvt_ids.dll (исправление ошибки для std::codecvt; см. вопрос о переполнении стека)
Если некоторые из дополнительных функций, перечисленных выше, не используются, двоичный файл может работать со старыми версиями C Runtime.