Implicit vs. Explicit linking to a DLL

后端 未结 3 797
無奈伤痛
無奈伤痛 2021-01-05 05:17

When one should implicitly or explicitly link to a DLL and what are common practices or pitfalls?

相关标签:
3条回答
  • 2021-01-05 06:05

    I'm assuming you refer to linking using a .lib vs loading a DLL dynamically using LoadLibrary().

    Loading a DLL statically by linking to its .lib is generally safer. The linking stage checks that all the entry points exist in compile time and there is no chance you'll load a DLL that doesn't have the function you're expecting. It is also easier not to have to use GetProcAddress().

    So generally you should use dynamic loading only when it is absolutely required.

    0 讨论(0)
  • 2021-01-05 06:06

    I agree with other who answered you already (Hans Passant and shoosh). I want add only two things:

    1) One common scenario when you have to use LoadLibrary and GetProcAddress is the following: you want use some new API existing in new versions of Windows only, but the API are not critical in your application. So you test with LoadLibrary and GetProcAddress whether the function which you need exist, and use it in the case. What your program do if the functions not exist depend total from your implementation.

    2) There are one important options which you not included in your question: delayed loading of DLLs. In this case the operating system will load the DLL when one of its functions is called and not at the application start. It allows to use import libraries (.lib files) in some scenarios where explicitly linking should be used at the first look. Moreover it improve the startup time of the applications and are wide used by Windows itself. So the way is also recommended.

    0 讨论(0)
  • 2021-01-05 06:09

    It is fairly rare to explicitly link a DLL. Mostly because it is painful and error prone. You need to write a function pointer declaration for the exported function and get the LoadLibrary + GetProcAddress + FreeLibrary code right. You'd do so only if you need a runtime dependency on a plug-in style DLL or want to select from a set of DLLs based on configuration. Or to deal with versioning, an API function that's only available on later versions of Windows for example. Explicit linking is the default for COM and .NET DLLs.

    More background info in this MSDN Library article.

    0 讨论(0)
提交回复
热议问题