The concept of the library
Libraries are ways of sharing program code. A library is essentially a binary format of executable code that can be loaded into memory for execution. In the development process, some core technologies or common frameworks do not want to be known to the outside world for the sake of security and stability, so the core code will be packaged into a library, exposing only the early files for use. The library is divided into static library and dynamic library.
Static library
Static libraries, in iOS, will be packaged as.a files, along with.h header files to complete the function calls. But conceptually, static libraries are an all-in-one design approach, because code that relies on static libraries links them completely into the App’s executable (Mach-O). That is, the static library is linked to the App in the compiler, so if multiple apps reference the same static library, each App will link to a copy of that static library. Static libraries can cause large Mach-O files, which directly affect app startup time and memory usage during execution. When using static libraries, it must manually link the external libraries it depends on one by one. For example, in the early wechat Payment SDK’s static library access method, it must be manually linked: SystemConfiguration framework, libz. Dylib libsqlite3.0. Dylib, libc++. Dylib, Security. The framework, CoreTelephony. Framework, CFNetwork. Framework In addition, due to the characteristics of static libraries, the memory of the static library needs to be reloaded every time the App is started, and the loading time cannot be controlled. Most of the time, you also need to put objC-all_load in Other Linker Flags to make sure the static library works.
The dynamic library
Dynamic libraries, most of them will be packaged as.tbd files or.dylib files. Unlike static libraries that link to the App at compile time, dynamic libraries link to the App at run time, so it has three benefits:
Loading on demand improves the efficiency of app startup because multiple apps use the same dynamic library. Therefore, once a dynamic library is loaded into the memory, there is no need to spend memory to load the dynamic library when the next app uses it, and everyone shares the same dynamic library. Because dynamic libraries do not need to participate in the compilation process, there is no problem with clashing symbols at link time.
However, Apple’s full support for dynamic libraries is limited to the system’s dynamic libraries, such as UI.framework. For third-party dynamic libraries, you still need to embed into the system. Some early hot update frameworks, such as JSPatch, slipped through the cracks to do hot updates via Dlopen, but they were quickly banned. However, if it is an enterprise certificate, you can still flexibly load the third-party dynamic library in your app.
Framework
In explaining static and dynamic libraries, I didn’t mention the word framework. Some developers think that framework files are dynamic libraries, which is not accurate. When we say framework, we mean.framework files, which are not necessarily static libraries or dynamic libraries. In fact, this is a way of packaging the Header, Binary, and bundle together to make it easy for developers to access and call. Therefore, whether the framework is a static or dynamic library depends on whether the Binary file is a static or dynamic library.
Pay attention to
Prior to iOS8, Apple did not allow third-party frameworks to load dynamically. Starting with iOS8, developers were allowed to create and use dynamic frameworks conditionally. This Framework is called Cocoa Touch Framework. It is also a dynamic framework, but unlike the System framework, dynamic libraries made using Cocoa Touch Framework in apps are put into the root of the App main bundle when they are packaged and submitted, and run in the sandbox instead of the system. In other words, even if different apps use the same framework, multiple frameworks will be signed, packaged and loaded separately. However, iOS8 has App Extension, which allows you to create plug-ins for an App, so it is possible to share dynamic libraries between the main App and the plugin. The Apple-specific framework is shared (such as UIKit), but our own dynamic libraries made using Cocoa Touch Framework are put into app bundles and run in sandboxes
CocoaPods
Introduction to the
CocoaPods is currently the most popular package management tool on iOS. It can be thought of as a component pool that can be automatically deployed to a project, and the corresponding Podfile is the equivalent of a Request for a component. When the components are downloaded to the project, cocoaPods automatically integrates the components into the existing project, puts all the dependent libraries into another project named Pods, and then makes the main project depend on the Pods project, so that the source management work is moved from the main project to the Pods project. The Pods project will eventually compile into a file called libPods_name. A or Pods_name. Framework, which the main project only relies on.
Before using the pod install command
After using the pod install command, a pod project, podfile. lock, is added. Xcworkspace named after the current project name
In CocoaPods, the following files exist:.podspec
The Pod description file, generally representing your project address, the platform and version used by the project, etc
.podfile
User written for the pod expected to load and the corresponding Target information
.podfile.lock
Records some information about the previous POD loading, including version, dependencies, CocoaPods version, and so on
.mainfest.lock
Records basic information about the local POD, which is actually a copy of podfile.lock
Pod Install operation principle analysis
When we run Pod Install, this happens:
-
Analyze the Dependency.
-
Compare the version of the local pod with the version of the pod in podfile.lock
-
Compare podfiles to see if they have changed.
-
If there is a problem, two lists are generated, one for pods (s) that need to be added and one for pods (s) that need to be removed.
-
Remove the Pods to be removed (if any)
-
Add the required Pod(s).
-
If you are using the regular CocoaPods library (if based on Git), you will first go to:
- Find the corresponding Pod folder under Spec
- Find the corresponding tag
- Locate its Podspec file
- Git clone the corresponding files (Bazaar, Mercurial, HTTP, SCP, SVN).
- Copy to the Pod folder
- Run the pre – Install hooks
-
Generate the Pod Project
- Add the corresponding file in this Pod to the project
- Add corresponding framework,. A libraries, and bundles
- Link headers file, generate Target
- Run the post – install hooks
-
Make podfile.lock, then make a copy of this file and place it in a Pod folder named manifest.lock
If The sandbox is not sync with The podfile.lock error occurs, manifest.lock and podfile.lock files are inconsistent.
-
Configure the original project file (Add Build Phase)
- Added Embed Pods Frameworks
- Added Copy Pods Resources
- Added Check Pods manifest.lock
Pre-install hook and post-install hook are callback functions that can be executed in podfiles before or after install.
Pre_install do | installer | # do some prior to installation of hook end post_install do | installer | # do some hook end after installationCopy the code
What changes have been made to the Xcode project
During the integration process between cocoaPods and the Xcode project, the following flow occurs
- Creat workspace Creates the xcWorkspace file. The xcWorkspace file is essentially just a collection of XcodeProjects with the following data structure:
<? The XML version = "1.0" encoding = "utf-8"? > < Workspace version = "1.0" > < FileRef location = "group: Demo/Demo. Xcodeproj" > < / FileRef > < FileRef location = "group:Pods/Pods.xcodeproj"> </FileRef> </Workspace>Copy the code
-
Create Group Creates a group folder in the project to logically isolate files
-
Create Pod Project & Add Pod Library Creates the Pod.xcodeProject project and introduces the third-party libraries defined in the Podfile into the project.
-
Add embed frameworks script phase added (CP) to embed the Pods frameworks, accordingly, much pods_xxx group, XXX. The following framework. Sh. To complete the packing of internal third-party libraries as a. A static library file (in Podfile if selected! Use_frameworks, this step is packaged as. Framework.)
-
If some third-party libraries have been removed from the podfile, this step will remove unwanted third-party libraries, removing their references from the Pod.xcodeProject project.
-
add copy resource script phase
If the third-party inventory is in the resource bundle, this step copies the resource files to a centralized directory for unified packaging and encapsulation. Accordingly, the [CP] Copy Pods Resources script is added. -
Add check manifest.lock Script Phase As mentioned earlier, manifest.lock is actually a copy of Podfile.lock. This step diff, and if there are inconsistencies, The famous The sandbox is not sync with The podfile.lock error is displayed.
-
Add User Script phase This step is to transform the original project project files. After running pod Install, if you open the original project again, it will fail to compile because changes have been made.
1. First, add a dependency on the Pod project by referencing the libpods_xxx.a file. The. A file (or. Framework file) in this step is the same file that was packaged in xxx.framework.sh in the previous step.
2. Create Pods group containing PODs-XXX-debug. xconfig and PODs-xxx.release.xconfig. These two files are the configuration of the build phase corresponding to the project. Accordingly, the debug and Release Configurations of the main project Iinfo->Configurations correspond to the above two configuration files.
3. What do the above two configurations do? Include:
Header_search_path, pointing to Pod/Headers/public/ XXX, added the compiled header address of Pods file Other_LDFLAGS, added -objc, etc., some Pods changed like Pods_BUILD_DIR etc
At this point, the original Xcode project and the new Pod project have completed integration and fusion.