Android startup process
1. Start the init process
- The boot button boot chip loads the BootLoader from ROM to RAM.
- Boot the BootLoader to pull up the Android OS.
- The Linux kernel starts and executes the main function of init. CPP to create the init process.
- Init creates and mounts the files and directories required for startup, initializes the property service, starts the property service, parses the init.rc configuration file, and starts the Zygote process.
2. Start the Zygote process
-
The Zygote process
The DVM (Dalvik Virtual Machine) and ART, application processes and SystemServer processes for system critical services in Android are all created by Zygote.
Zygote (incubator) creates application processes and SystemServer by forking Dalvik/ART at startup
So every process created by Zygote has a separate instance copy of the DVM/ART virtual machine. This is why Android applications are independent, secure, and stable, and can’t be killed by a single process error.
-
The Zygote process is started
- Call the start method to start the Zygote process.
- Create a Java virtual machine and register JNI methods for the virtual machine.
- The Java framework layer of Zygote is accessed by calling zygoteinit. Java’s main function through the JNI method.
- Preload classes and resources, and start SystemServer.
- The server-side Socket is created through the registerZygoteSocket method, and the new application process is created by waiting for AMS’s request through the runSelectLoop method.
-
Sequence diagram:
3. Start the SystemServer process
-
SystemServer process
The SystemServer process is primarily used to create system services, such as AMS, WMS, and PMS.
-
Start the Service process
- Start the Binde thread pool so that you can communicate with other processes.
- Create SystemServiceManager to create and start the lifecycle management for system services.
- Start various system services (boot services, core services, other services).
-
Sequence diagram
4. Launcher process
-
Launcher
When the system starts up to the last step, it starts an application program, which is commonly seen as the application desktop, called the Launcher. When the program starts up, it requests the PackageManagerService to get the installed applications of the current system. And encapsulate their app information as a shortcut to display on our desktop screen, so that users can tap the app icon to launch the app.
So Launcher has two features:
- As the initiator of the Android system, it is used to start applications.
- As an Android desktop, used to display and manage shortcut ICONS of applications or other desktop components.
-
Sequence diagram
Summary: Android system startup process
- Start the power supply and the system. (Boot chip executes from a predefined place in ROM, loads the main boot BootLoader into RAM)
- Boot program BootLoader. (Pull system OS up)
- The Linux kernel is started. Set up cache, protected storage, schedule list, load driver. When the kernel is finished, first look for the init.rc file in the system file and start the init process.)
- The init process starts. Initialize and start the properties service, and start the Zygote process.
- The Zygote process is started. (Create a Java VIRTUAL machine, register the JNI method for the Java VIRTUAL machine, create a server Socket, and start the SystemServer process.)
- The SystemServer process is started. Start Binder thread pools and SystemServiceManager, and start various system services.
- Start the Launcher. (AMS started by the SystemServer process launches the Launcher, which displays installed application shortcut ICONS on the desktop.)
Here is:
Application startup process
If an application is started, AMS detects whether the application process exists and creates a request to Zygote if it does not.
We know that Zygote’s Java framework layer creates a server-side Socekt that waits for AMS to create a new application process request. After AMS makes the request, Zygote creates the application by fock’s own process so that the application process has a virtual machine instance at startup. Binder thread pools and message loops are also created so that applications running within the application process can communicate between processes and handle messages.
1. AMS sends the sequence diagram of the request to start the application process
2. Zygote receives the request and creates a sequence diagram of the application process
We see similarities between this sequence diagram and the SystemServer startup sequence diagram mentioned above. They all start with applicationInit, where ZygoteInit calls RuntimeInit, and follow the same process.
*** Why does Android call MethodArgsCall instead of SystemService main or ActivityThread main? 支那
** because the handling of the thrown exception clears all stack frames (memory optimization) required by the setup process **
3. Message loop creation process
ActivityThread is the main thread used to manage the current application process. Some of the key source code is as follows:
public static void main(String[] args){...// Create the main thread Looper
Looper.prepareMainLooper();
ActivityThread thread = new ActivityThread();
thread.attach(false);
if(sMainThreadHandler == null) {// Create the main thread H class
sMainThreadHandler = thread.getHandler();
}
if(false){
Looper.myLooper().setMessageLogging(new LogPrinter(Log.DEBUG, "ActivityThread"));
}
Trace.traceEnd(Trace.TRACE_TAG_ACTIVITY_MANAGER);
// Looper starts to work
Looper.loop();
throw new RuntimeException("Main thread loop unexpectedly exited");
}
Copy the code
Four components work process
1. Root the Activity startup process
There are two types of activities: root Activity and normal Activity. However, common activities and root activities start in a similar way, the root Activity is more representative.
The root Activity startup process is complex and consists of three parts: the request FOR AMS from AMS to ApplicationThread, and the start of the Activity from ActivityThread.
- AMS sequence diagram of Launcher request:
* * * note: IActivityManager for AMS proxy objects, it is in the Instrumentation by ActivityManager getService () method. See ActivityManager source code below: **
public static IActivityManager getService(a){
return IActivityManagerSingleton.get();
}
private static final Singleton<IActivityManager> IActivityManagerSingleton = new Singleton<IActivityManager>(){
@Override
protected IActivityManager create(a){
// AMS references of Binder type
final IBinder b = ServiceManager.getService(Context.ACTIVITY_SERVICE);
// So IActivityManager here is actually a proxy object for AMS
final IActivityManager am = IActivityManager.Stub.asInteface(b);
returnam; }}// Android8.0 uses the AIDL form to communicate with AMS processes, while Android7.0 uses an ActivityManagerProxy object similar to AIDL.
Copy the code
-
AMS to ApplicationThread call sequence diagram:
*** Note: ApplicationThread is an inner class of ActivityThread that inherits from iApplicationThread.stub. It is used for interprocess communication with AMS
Communication between AMS and application processes:
-
ActivityThread starts an Activity:
*** Note: Class H is an inner class of ActivityThread that inherits from Handler. Because ApplicationThread code runs in the Binder thread pool, the code is cut back to the main thread through class H for subsequent operations **
2. Root the process involved in starting the Activity
The root Activity startup process involves four processes: Zygote process, Launcher process, AMS process (SystemServer process) and application process.
- Diagram:
- Sequence diagram:
* Note: How many processes are involved in the normal Activity startup process? The answer is two, the AMS process and the application process.
3. Service startup process
The process of starting a Service is similar to that of an Activity. It is ContextImpl to AMS and ActivityThread to start the Service.
-
ContextImpl to AMS sequence diagram
-
ActivityThread Starts the Service sequence diagram