I have read many articles about static/dynamic library/framework. So my understanding is (let me know if it’s inaccurate):
Framework = Library + Bundle
Static = Linking at build time
Dynamic = Linking at run time
In Xcode, we have "Static Library" and "Framework". Which raises a few confusing points:
- Why there’s no "Dynamic Library" option?
- Given that we can already link framework statically, why do we still need a "Static Library"? (isn’t StaticFramework = StaticLibrary + Bundle? )
2
Answers
Because Dynamic Library is not permitted for iOS apps at beginning.
Because old Xcode only support
Static Library
.Static Framework
was added later, and they keep theStatic Library
.There are many concepts that must be clear
Libraries have two categories based on how they are linked to the executable file
.a
,.so
. link at compile time. wiki.dylib
.dll
etc. link at runtime. only apple can use it for iOS for some safe reason, we cannot build this.ps, a special kind in apple platform
Text Based
.dylib
stubs —.tbd
Framework
Framework is a package that can contain resources such as dynamic libraries, strings, headers, images, storyboards etc.
vs Libraries, Framework has more features
Framework also has static and dynamic
iOS 8 later, we can use a dynamic framework, why Apple releases this. maybe Extension and App share code
this Dynamic Framework for iOS is named embedded frameworks, because when we build the app copy the framework in app bundle.
so the embedded framework is different from system dynamic Frameworks like
UIKit.Framework
the embedded library is allowed with the
Framework
option, but dynamic framework shared in muti app is also not allowedwell, Xcode not only support Objective-c and Swift, but also support C, C++ which may use the static library