Static vs dynamic linking
What is static linking?
Static linking links libraries at compile time, copying them to the final binary.
What is dynamic linking?
Dynamic linking loads and links libraries at runtime, loading them to memory.
Only the name of the shared libraries is saved at compile time.
These names are saved in a PLT (Procedure Linkage Table)
Static vs dynamic linking
Static
Bigger binaries
Updates to shared library code can add breaking changes and prevent the program from running
Dynamic
Depend on external libraries to be installed and be compatible
Shared libraries are shared across processes
Shared library code can be updated/patched without new compilation
How to create a statically linked binary?
$ ld [options] objfile
ld
combines several object and archive files, relocates their data and ties up symbol references. Usually, the last step in compiling a program is to run ld
.
$ gcc hello.c -static -o hello
How to create a dynamically linked binary?
$ gcc hello.c -o hello
How to know if a binary is statically or dynamically linked?
Check the type of linking
$ file /usr/bin/gcc
/usr/bin/gcc: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=017fc52acbca077c9bc6a4e8f04dd90eb5385243, for GNU/Linux 4.4.0, stripped
Check dynamically linked libraries
$ ldd /bin/gcc
linux-vdso.so.1 (0x00007fff6377e000)
libc.so.6 => /usr/lib/libc.so.6 (0x00007fcd238f2000)
/lib64/ld-linux-x86-64.so.2 => /usr/lib64/ld-linux-x86-64.so.2 (0x00007fcd23b02000)