Ошибка lnk1104 не удается открыть файл kernel32 lib

Today in Visual Studio 2017 I had the same problem.

The cause in my case turned out to be a bad environment setting in NETFXSDKDir (NETFXSDKDir=C:Program Files (x86)Windows KitsNETFXSDK4.6.1). It needs to be instead NETFXSDKDir=C:Program Files (x86)Windows Kits10Lib10.0.10240.0umx86. Specifically, as set in this batch file (my directory actually has 4 different files) for the Command Prompt for VS2017:

%comspec% /k "C:Program Files (x86)Microsoft Visual Studio2017EnterpriseVCAuxiliaryBuildvcvars32.bat"

as I am reluctant to change one of the «as installed» batch files… even more as that batch file calls another yet another:

@call "%~dp0vcvarsall.bat" x86 %*

…instead for my specific C++ command-line app, I simply added the explicit path text: ;C:Program Files (x86)Windows Kits10Lib10.0.10240.0umx86 for a total string in «Library Directories» like this: $(VC_LibraryPath_x86);$(WindowsSDK_LibraryPath_x86);$(NETFXKitsDir)Libumx86;C:Program Files (x86)Windows Kits10Lib10.0.10240.0umx86. (Right click on project, Properties → Configuration Properties → VC++ Directories → Library Directories.) That resolved my «fatal error LNK1104: cannot open file ‘kernel32.lib'» error. I found that hint in this GitHub issue.

Note this is reproducible in Visual Studio 2017 Enterprise 2017 Version 15.1 (26403.0) even after successful «repair» install… when creating a new Visual C++ Win32 Console Application and attempting to compile.

In fact, unless a blank application is created, the default template also includes reference to <SDKDDKVer.h> and with that I get this additional error: Error (active) E1696 cannot open source file "SDKDDKVer.h". So I created an empty C++ project.

I ran into this problem recently (few days ago everything was working fine): Visual Studio 2012 started to refuse to build native WP8 projects.

Today, I created new solution from template ‘Windows Phone Direct3D App (Native Only)’ to check if my newly created DLLs will be properly supported on WP. I tried to compile this project, first without any changes or additional references — pure code generated by VS. However, it failed with given error.
I know very well what does it mean and what could be the possible reason, but I can’t understand, hovewer, where does it come from in this case.
Weird thing: this only happens in ‘Win32’ configuration, ARM compiles fine:

1>------ Build started: Project: PhoneDirect3DApp, Configuration: Debug ARM ------
.......

Build Summary
-------------
00:11.742 - Success - Debug ARM - PhoneDirect3DAppPhoneDirect3DApp.vcxproj

but Win32 does not:

1>------ Build started: Project: PhoneDirect3DApp, Configuration: Debug Win32 ------
.......
1>LINK : fatal error LNK1104: cannot open file 'kernel32.lib'

Build Summary
-------------
00:09.725 - Failed  - Debug Win32 - PhoneDirect3DAppPhoneDirect3DApp.vcxproj

My standard (native C++/Win32) projects also work as expected (in both Win32 and x64 platform targets).

Project configuration: (in both platforms)

Linker::Input:

d3d11.lib;%(AdditionalDependencies)

Linker::Ignore:

ole32.lib;%(IgnoreSpecificDefaultLibraries)

VC++ Directories:

Microsoft.ARM.Cpp.User:

$(WP80ToolSetPath)libarm;$(WindowsSDK_LibraryPath_ARM);

Microsoft.Win32.Cpp.User:

$(VCInstallDir)lib;$(VCInstallDir)atlmfclib;$(WP80ToolSetPath)libx86;$(WindowsSDK_LibraryPath_x86)

Any ideas what else could be wrong or configured incorrectly? I’m running out of ideas, I have never seen something like this before.

By the way, I have noticed one more change: when I was trying to compile WP8 projects in ARM configurtion before, there was always an error, saying «building ARM application on desktop is not supported» (or something like that). Now ARM compiles with no problem. Is it normal?

  • Remove From My Forums
  • Question

  • Hi All

    OK so i know there is A LOT on this error floating around. I am a complete newb to VS 2008. i’ve just done a complete install of Visual Studio 2008 on Xp32 SP2 etc, with the view of using it as a simple compiler for now, and moving onto building app later.

    Having created a new empty project, added a .cpp file and created the simplest of simple Hello world applications i get the following linking error:

    1>—— Build started: Project: hello, Configuration: Debug Win32 ——
    1>Linking…
    1>LINK : fatal error LNK1104: cannot open file ‘kernel32.lib’
    1>Build log was saved at «file://c:CPPhellohelloDebugBuildLog.htm»
    1>hello — 1 error(s), 0 warning(s)
    ========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

    I’ve not touched or configured anything to get this error. Since this i have been googling like mad, and most replies just say «check your linker settings» etc. But there is nothing there. I’ve tried adding multiple different paths to the linker dependancies and the VC++ DIrectories and nothing

    On my system, the only Kernel32.lib is located at:
    C:Program FilesMicrosoft SDKsWindowsv5.0LibIA64

    But surely this is for 64 bit platforms? Sometimes adding this path results in an expected error of it not being the right target machine.

    I’ve tried adding the path to the folder and to the file to the linker dependancies, i’ve tried adding it to the VC++ Directories for all entries except include. Basically anything that i’ve found suggested on the net.

    This is so frustrating as i’ve not done anything other than install VS and it wont work! So i dont know am i missing something?

    Many thanks in advance

    ‘Oom

Answers

  • You have not provided all pertinent information.

    Quote>i’ve just done a complete install of Visual Studio 2008

    Was this actually VS or was it one or more of the language products?

    Which edition? Express? Standard? Professional? Note that this

    forum is for issues related to the Express Editions of VC++.

    If VC Express, how did you install it? Via the MS web install or via

    a downloaded ISO disc?

    If Express, what other supporting libraries have you installed?

    MSDN? Win32 SDK?

    Quote>On my system, the only Kernel32.lib is located at:
    Quote>C:Program FilesMicrosoft SDKsWindowsv5.0LibIA64

    When and why did you install this version of the SDK? What is your

    hardware platform? You have the SDK libs for Itanium processors.

    It is certainly not the latest, and not even as recent as the version

    originally available when VC 2008 was initially released. If you are

    running on an Intel/AMD x86 system you should have at least v6.0a and

    there should be a kernel32.lib for 32-bit (in lib) and one for 64-bit (in Libx64).

    If you actually do have Visual Studio 2008, you may not have completed

    the full installation.

    — Wayne

title description ms.date f1_keywords helpviewer_keywords ms.assetid

Linker Tools Error LNK1104

Describes the Microsoft C and C++ (MSVC) linker error LNK1104, its causes, and possible solutions.

12/13/2019

LNK1104

LNK1104

9ca6f929-0efc-4055-8354-3cf5b4e636dc

cannot open file ‘filename

This error is reported when the linker fails to open a file, either for reading or for writing. The two most common causes of the issue are:

  • your program is already running or is loaded in the debugger, and

  • your library paths are incorrect, or aren’t wrapped in double-quotes.

There are many other possible causes for this error. To narrow them down, first check what kind of file filename is. Then, use the following sections to help identify and fix the specific issue.

Can’t open your app or its .pdb file

Your app is running, or it’s loaded in the debugger

When filename is your executable’s name, or an associated .pdb file, see if your application is already running. Then check whether it’s loaded in a debugger. To fix this issue, stop the program and unload it from the debugger before building it again. If the app is open in another program, such as a resource editor, close it. If your program is unresponsive, you may need to use Task Manager to end the process. You might also need to close and restart Visual Studio.

Your app is locked by an antivirus scan

Antivirus programs often temporarily block access to newly created files, especially .exe and .dll executable files. To fix this issue, try excluding your project build directories from the antivirus scanner.

Can’t open a Microsoft library file

Windows libraries, such as kernel32.lib

If the file that can’t be opened is one of the standard library files provided by Microsoft, such as kernel32.lib, you may have a project configuration error or an installation error. Verify the Windows SDK has been installed. If your project requires other Microsoft libraries, such as MFC, make sure the MFC components were also installed by the Visual Studio installer. You can run the installer again to add optional components at any time. For more information, see Modify Visual Studio. Use the Individual components tab in the installer to choose specific libraries and SDKs.

Versioned vcruntime libraries

If the error message has a versioned Microsoft library such as msvcr120.lib, the platform toolset for that compiler version may not be installed. To fix this issue, you have two options: Upgrade the project to use the current platform toolset, or install the older toolset and build the project unchanged. For more information, see Upgrading Projects from Earlier Versions of Visual C++ and Use native multi-targeting in Visual Studio to build old projects.

Retail, Debug, or platform-specific libraries

The error may occur when you first build for a new target platform or configuration, such as Retail, or ARM64. In the IDE, verify the Platform toolset and Windows SDK Version specified in the General property page are installed. Also verify the required libraries are available in the Library Directories specified in the VC++ Directories Property Page. Check the properties for each configuration, such as Debug, Retail, x86, or ARM64. If one build works but another doesn’t, compare the settings for both. Install any missing required tools and libraries.

The vccorlib.lib library

There are no Spectre-mitigated libraries for Universal Windows (UWP) apps or components. If the error message includes vccorlib.lib, you may have enabled /Qspectre in a UWP project. Disable the /Qspectre compiler option to fix this issue. In Visual Studio, change the Spectre Mitigation property. It’s found in the C/C++ > Code Generation page of the project Property Pages dialog.

Libraries in projects from online or other sources

If you build a project copied from another computer, the library installation locations may be different. For command-line builds, verify the LIB environment variable and library paths are set correctly for the build. In Visual Studio, you can see and edit the current library paths set in the Property pages for your project. In the VC++ Directories page, choose the drop-down control for the Library Directories property, then choose Edit. The Evaluated value section of the Library Directories dialog lists the current paths searched for library files. Update these paths to point to your local libraries.

Updated Windows SDK libraries

This error can occur when the Visual Studio path to the Windows SDK is out of date. It may happen if you install a newer Windows SDK independently of the Visual Studio installer. To fix it in the IDE, update the paths specified in the VC++ Directories property page. Set the version in the path to match the new SDK. If you use the Developer Command Prompt, update the batch file that initializes the environment variables with the new SDK paths. This problem can be avoided by using the Visual Studio installer to install updated SDKs.

Can’t open a third-party library file

There are several common causes for this issue:

  • The path to your library file may be incorrect, or not wrapped in double-quotes. Or, you may not have specified it to the linker.

  • You may have installed a 32-bit version of the library but you’re building for 64 bits, or the other way around.

  • The library may have dependencies on other libraries that aren’t installed.

To fix a path issue for command-line builds, verify the LIB environment variable is set. Make sure it includes paths for all the libraries you use, and for every configuration you build. In the IDE, the library paths get set by the VC++ Directories > Library Directories property. Make sure all the directories that contain the libraries you need are listed here, for every configuration you build.

You might need to supply a library directory that overrides a standard library directory. On the command line, use the /LIBPATH option. In the IDE, use the Additional Library Directories property in the Configuration Properties > Linker > General property page for your project.

Make sure you install every version of the library you need for the configurations you build. Consider using the vcpkg package management utility to automate the installation and setup for many common libraries. When you can, it’s best to build your own copies of third-party libraries. Then you’re sure to have all the libraries’ local dependencies, built for the same configurations as your project.

Can’t open a file built by your project

You may see this error if filename doesn’t exist yet when the linker tries to access it. It can happen when one project depends on another in the solution, but the projects build in the wrong order. To fix this issue, make sure your project references are set in the project that uses the file. Then the missing file gets built before it’s required. For more information, see Adding references in Visual Studio C++ projects and Managing references in a project.

Can’t open file ‘C:Program.obj’

If you see the filename C:Program.obj in the error message, wrap your library paths in double quotes. This error happens when an unwrapped path that begins with C:Program Files gets passed to the linker. Unwrapped paths may also cause similar errors. Typically, they show an unexpected .obj file in the root of your drive.

To fix this issue for command-line builds, check the /LIBPATH option parameters. Also check the paths specified in the LIB environment variable, and the paths specified on the command line. Make sure to use double-quotes around any paths that include spaces.

To fix this issue in the IDE, add double-quotes as necessary to the following properties for your project:

  • The Library Directories property on the Configuration Properties > VC++ Directories property page,

  • The Additional Library Directories property in the Configuration Properties > Linker > General property page,

  • The Additional Dependencies property in the Configuration Properties > Linker > Input property page.

Other common issues

Path or filename issues

This error can occur when the library filename or path specified to the linker is incorrect. Or, when the path has an invalid drive specification. Look on the command line or in any #pragma comment( lib, «library_name» ) directive for issues. Check your spelling and the file extension, and verify the file exists at the specified location.

Parallel build synchronization

If you’re using a parallel build option, Visual Studio may have locked the file on another thread. To fix this issue, verify the same code object or library isn’t built in multiple projects. Use build dependencies or project references to pick up built binaries in your project.

Additional dependencies specified in the IDE

When you specify individual libraries in the Additional Dependencies property directly, use spaces to separate the library names. Don’t use commas or semicolons. If you use the Edit menu item to open the Additional Dependencies dialog box, use newlines to separate the names, not commas, semicolons, or spaces. Also use newlines when you specify library paths in the Library Directories and Additional Library Directories dialog boxes.

Paths that are too long

You may see this error when the path for filename expands to more than 260 characters. If needed, rearrange your directory structure or shorten your folder and file names to shorten the paths.

Files that are too large

This error can occur because the file is too large. Libraries or object files more than a gigabyte in size may cause problems for the 32-bit linker. A possible fix for this issue is to use the 64-bit toolset. For more information on how to use the 64-bit toolset at the command line, see How to: Enable a 64-Bit Visual C++ Toolset on the Command Line. For information on how to use the 64-bit toolset in the IDE, see Using MSBuild with the 64-bit Compiler and Tools. Also see this Stack Overflow post: How to make Visual Studio use the native amd64 toolchain.

Incorrect file permissions

This error can occur if you have insufficient file permissions to access filename. It may happen if you use an ordinary user account to access library files in protected system directories. Or, if you use files copied from other users that still have their original permissions set. To fix this issue, move the file to a writeable project directory. If the moved file has inaccessible permissions, run the takeown.exe command in an Administrator command window to take ownership of the file.

Insufficient disk space

The error can occur when you don’t have enough disk space. The linker uses temporary files in several cases. Even if you have sufficient disk space, a large link can deplete or fragment the available disk space. Consider using the /OPT (Optimizations) option; doing transitive COMDAT elimination reads all the object files multiple times.

Problems in the TMP environment variable

If the filename is named LNKnnn, it’s a filename generated by the linker for a temporary file. The directory specified in the TMP environment variable may not exist. Or, more than one directory may be specified for the TMP environment variable. Only one directory path should be specified for the TMP environment variable.

Help, my issue isn’t listed here!

When none of the issues listed here apply, you can use the feedback tools in Visual Studio for help. In the IDE, go to the menu bar and choose Help > Send Feedback > Report a Problem. Or, submit a suggestion by using Help > Send Feedback > Send a Suggestion. You can also use the Microsoft Learn Q&A site for questions, and the Visual Studio C++ Developer Community website. Use these sites to search for answers to questions and ask for help. For more information, see How to report a problem with the Visual C++ toolset or documentation.

If you’ve discovered a new way to fix this issue that we should add to this article, let us know. You can send us feedback by using the button below for This page. Use it to create a new issue in our C++ documentation GitHub repo. Thanks!

Я получаю эту ошибку с тех пор, как я установил .NET Framework SDK для 64-разрядного программирования на моем компиляторе Visual C++ 2010 Express. Я не могу скомпилировать даже простую программу вообще из-за этой единственной ошибки, которую я получаю. Моя платформа-x86. Вот snap shot, если это поможет:

enter image description here

Я не знаю, что еще сказать. Я только что загрузил этот компилятор вчера, и он работал нормально. Я хотел перейти с 32-битного программирования на 64-бит, чтобы я мог работа со сборкой, поэтому я загрузил это SDK. Я искал в Google и даже здесь, в Stackoverflow. Google не очень помог, но я нашел сообщение здесь это казалось похожим на мой, но ответы не сделали много справедливости. Кто-нибудь знает, почему эта ошибка происходит и как я могу избавиться от него?

13 ответов


Проверьте каталоги VC++, в VS 2010 их можно найти в свойствах вашего проекта. Проверьте ли $(WindowsSdkDir)lib входит в список каталогов, если нет, вручную добавьте его. Если вы строите для платформы X64, вы должны выбрать X64 из» платформы » ComboBox и убедитесь, что $(WindowsSdkDir)libx64 входит в список каталогов.


измените набор инструментов платформы на: «Windows7.1SDK » в разделе свойства проекта — >свойства конфигурации — >общие


убедитесь, что у вас есть в каталогах VC++ (щелкните правой кнопкой мыши проект, выберите страницу свойств),

  • Включить Каталоги: $(IncludePath)
  • каталоги библиотеки элементов списка: $(LibraryPath)

только для пользователей командной строки (т. е. — makefile):

  1. при установке VC++ Express, это только 32-разрядный. Итак, все идет в C:Program Файлы (x86).
  2. затем вы решаете обновить до 64-разрядных capabillities. Итак, вы устанавливаете SDK. Но он 64-битный. Итак, все идет в C:Program Файлы.

Вы (как и я), вероятно, «настроили» свой makefile на #1, выше, через что — то вроде это:

MS_SDK_BASE_DOS := C:Program Files (x86)Microsoft SDKsWindowsv7.0A
ENV_SET         := LIB="$(MS_SDK_BASE_DOS)Libx64"

но теперь вам нужно изменить эту настройку на #2, выше, вот так:

MS_SDK_BASE_DOS := C:Program FilesMicrosoft SDKsWindowsv7.1

(Не пропустите » v7.0A » to » v7.- Перемены тоже.)


Я получил аналогичную ошибку, проблема остановилась, когда я проверил список «Компоновщик — > ввод — > дополнительные зависимости» в свойствах проекта. Мне не хватало половины двоеточия»; «непосредственно перед» %(AdditionalDependencies)».
У меня также была одна и та же запись дважды. Этот список следует редактировать отдельно для отладки и выпуска.


добавить lib путь WindowsSdks в проекте — >свойства — >свойства конфигурации — > каталоги VC++ -> каталоги библиотек.

Я добавил следующий путь и ошибок::

C:Program файлы (x86)Microsoft SDKsWindowsv7.1A Lib;

моя система Win-7, 64bit, VS 2013, .net framework 4.5

2

автор: Ujjaval Moradiya


У меня была другая проблема в Windows 10 с Visual Studio 2017, но с теми же эффектами. Я думаю, что мои проблемы сводились к тому, что VS был установлен на диск, отличный от «C:». Я решил проблему, переустановив Windows 10 SDK

сначала мне пришлось удалить Windows SDK (было установлено две версии). Затем запустил исполняемый файл. После установки запустите visual studio, и он работал нормально.


enter image description here

решение Джеро сработало для меня.
В Visual Studios 2012 выполните следующие действия.
— Перейдите в Обозреватель решений
— Правой кнопкой мыши на вашем проекте
— Перейти к свойствам
— Свойства Конфигурации -> Общие
— Набор Инструментов Платформы ->изменить на Windows7.1SDK


Если вышеуказанное решение не работает, проверьте, есть ли у вас $(LibraryPath) в свойствах — > каталоги VC++ — >каталоги библиотеки. Если вы упускаете его, попробуйте добавить.


ОС: Win10, Visual Studio 2015

решение :
Перейдите в Панель управления — — — > удалить программу — — — MSvisual studio — — — — > изменить — — — — >организовать = ремонт

и восстановить его.
Обратите внимание, что вы должны подключиться к интернету до завершения ремонта.

удачи.


сегодня в Visual Studio 2017 у меня была та же проблема.

причиной в моем случае оказалась плохая настройка среды в NETFXSDKDir (NETFXSDKDir=C:Program Files (x86)Windows KitsNETFXSDK.6.1). Это должно быть вместо NETFXSDKDir=C:Program Files (x86)Windows KitsLib.0.10240.0umx86. В частности, как установлено в этом пакетном файле (мой каталог фактически имеет 4 разных файла) для командной строки для VS2017:

%comspec% /k "C:Program Files (x86)Microsoft Visual Studio17EnterpriseVCAuxiliaryBuildvcvars32.bat"

поскольку я не хочу менять один из» установленных » пакетных файлов… еще больше, поскольку этот пакетный файл вызывает еще один другой:

@call "%~dp0vcvarsall.bat" x86 %*

…вместо этого для моего конкретного приложения командной строки C++ я просто добавил явный текст пути:;C:Program Files (x86)Windows KitsLib.0.10240.0umx86 для общей строки в «каталогах библиотеки», как это: $(VC_LibraryPath_x86);$(WindowsSDK_LibraryPath_x86);$(NETFXKitsDir)Libumx86;C:Program Files (x86)Windows KitsLib.0.10240.0umx86. (Щелкните правой кнопкой мыши проект, свойства → свойства конфигурации → каталоги VC++ → каталоги библиотеки.), Который разрешил мою «фатальную ошибку LNK1104: не удается открыть файл» kernel32.ошибка Либ'». Я нашел этот намек в этот вопрос GitHub.

Примечание это воспроизводимо в визуальном Studio 2017 Enterprise 2017 версии 15.1 (26403.0) даже после успешного «ремонта» установки… при создании нового консольного приложения Visual C++ Win32 и попытке компиляции.

фактически, если не создано пустое приложение, шаблон по умолчанию также включает ссылку на <SDKDDKVer.h> и с этим я получаю эту дополнительную ошибку:Error (active) E1696 cannot open source file "SDKDDKVer.h". Так Что Я создал пустой проект c++.


на Visual Studio 2017, Я пошел к Свойства Проекта ->Свойства Конфигурации ->общие, отобранных Все Платформы (1), затем выберите выпадающий (2) под версия Windows SDK и обновлен с 10.0.14393.0 на тот, который был установлен (3). Для меня это было 10.0.15063.0.

enter image description here

дополнительная информация: это исправило ошибку в моем случае, потому что версия Windows SDK помогает VS выбрать правильные пути. каталоги VC++ -> Библиотека-Каталоги -> редактировать ->макрос -> показывает, что макрос $(WindowsSDK_LibraryPath_x86) имеет путь с номером версии выше.


Я просто встречался и решил эту проблему сам. Моя проблема немного другая. Я использую visual studio в Windows 10. Когда я создаю проект,Target Platform Version было автоматически установлено значение 10.0.15063.0. Но нет kernel32.lib для этой версии SDK также нет других необходимых файлов заголовков и файлов lib. Поэтому я изменил Target Platform Version до 8.1. И это сработало.

окружающая среда:

  • Windows 10
  • Visual Studio 2015
  • Visual C++

решение:

  1. открыть проект Property Page;
  2. перейти к General страница;
  3. изменить Target Platform Version на нужную целевую платформу (например,8.1).

Понравилась статья? Поделить с друзьями:
  • Ошибка livekernelevent 124
  • Ошибка license not found лицензия не найдена
  • Ошибка live initialization failed
  • Ошибка libvlccore dll
  • Ошибка list object has no attribute replace