tags:

views:

337

answers:

7

What are the use cases of using static libraries in C++? I have seen that people create DLLs instead or some that use static libraries only. Whats your recommendation?

+5  A: 

I'm a big fan of static libraries pretty much everywhere. The one big thing that DLLs get you that static libs cannot do is the ability to dynamically load and unload library functionality. So if your application is going to support some sort of hot swapping plugins, you need to use dynamic libs. Otherwise you can probably use static libs.

Static libs open the door to a lot of optimizations that you can't do with dynamic libs because they are performed at link-time. In the microsoft world Link Time Code Generation (LTCG) give you the ability to do whole program optimization and dead code stripping through not only your application, but also your libraries (in gcc this is called Link Time Optimization [LTO])

Additionally static libs tend to make your program easier to distribute because you aren't forced to pass around a lot of library files, and you can completely avoid DLL-hell if you ever were to version your library.

Chris
But then you end up with 20 executables that have the same 500kb lib embedded - 10 MB of wasted space!
George Edison
I'd rather sacrifice the 10MB of hard drive space (which is cheap) than ever have to deal with DLL-hell or microsofts SxS stuff. I've spent more hours debugging crazy dll loading errors than it would have taken me to earn enough money to by the extra 10MB of disk space at 1989 rates.
Chris
True. I am a bit of a hypocrite because I do the same thing myself when push comes to shove. (Think Visual C runtime!)
George Edison
+1 for mentioning avoiding DLL-hell.
sevity
Careful on the link-time code generation with static libs. It's fine as long as you're the one building the library for your own use, but if you plan to distribute the library you should be aware that whole program optimization can cause issues for your developers. This article explains more in-depth why you need to be careful: http://blogs.msdn.com/b/vcblog/archive/2009/02/24/quick-tips-on-using-whole-program-optimization.aspx
+1  A: 

There is the advantage of not having to recompile your entire program if you make a change to a dynamically linked library. @Chris makes a good point about dll-hell but if it s a minor bug fix that doesn't affect the API, this can save you the recompilation.

There is a SO post that talks about Windows not being able to apply updates to your program if you statically link their libraries (link to come). Although i think you are more talking about statically linking your own modules.

darren
Why would a change in a static library force you to recompile the entire program if the library's interface didn't change? I use static libraries all the time, and only the specific modules I touch get recompiled (if I don't touch the interface or inline functions, that is).
Emile Cormier
Oh, I see where you're coming from. You meant that if you change a shared library (without touching interface), you don't need to re-link and redeploy the main executable. I agree. But you made it sound like touching a static library would force recompilation of all main executable source files, and that is not the case (again, assuming no interface change).
Emile Cormier
ahh, sorry for not clarifying.
darren
A: 

Well a Static DLL would be for holding huge libraries and also for using Multi-Os coode as i like to call it so its able to be ran on linux , Windows ...

H4cKL0rD
+1  A: 

You should use shared libraries (DLL) if you have a significant functionality that needs to be shared between applications; AND this functionality may be improved independant of all the application and updates shipped seprately.

The 'AND' part is the hardest to fulfill: usually you ship your application with any new functionality added and never update the library without updating the application at the same time (I am not saying that never happens) but usually the two ship in lockstep.

Otherwise it is easier to just build normal libs and ship the application.

An Example of a good (I use the term loosely for example purposes) is DirectX. When a new version of DirectX is shipped (and the interface has not changed) you just need to update the DLL and all apllications that use DirectX get the benifit of the new version of the library. In reality it is not quite that simple but you get the idea.

Martin York
A: 

I use static libraries to implement UML's "package" concept. All modules belonging to a package gets put into their own subdirectory, and I create an IDE subproject or makefile for that directory which builds a static library *.a file. Modern IDEs make it possible to work with your top-level package along with sub-packages within the same "workspace".

If a package (or a group of packages) can be deployed separately from the main executable, then I compile it into a shared library (*.so or *.dll) instead and consider it a "component" in UML jargon.

Emile Cormier
It gets a bit confusing figuring out what entities map into UML's package, component, and subsystem concepts.
Emile Cormier
+2  A: 

In general, although there are always exceptions to the rule, I would say:

Advantages of DLLs

  • Less physical memory usage when running multiple instances of an application. (Copy on write optimisation of memory usage.)
  • Faster link times.
  • Smaller executables.
  • Better modularity.

Advantages of static libraries

  • Less virtual memory usage (and probably less physical memory usage) when running a single instance of an application.
  • Performance. Approximately 10% (more or less) improvement over DLLs, depending on your application.
  • Reliability. You tested your application against a specific version (or specific versions) of a library. An upgrade to a DLL could potentially break your application.
Nelson
+1  A: 

Use static version of your libraries where you can. Use dynamic libraries where you need to (license, availability or plugin system).

Klaim
Yes, this. DLLs are extra complication, extra rules, less cross platform compatability, and extra security issues. Seldom as an app developer do you really want to unload a lib, or to truly share it with other apps.
Charles Eli Cheese