Current location - Quotes Website - Collection of slogans - There are several ways of cross-process communication in android development.
There are several ways of cross-process communication in android development.
Several communication modes between Android processes define multiple processes.

First, there is only one way to use multi-process in Android applications (except using the fork of NDK), and that is to use the android:process attribute to specify when declaring components in AndroidManifest.xml

If the process attribute is unknown, it will run in the main process by default, and the name of the main process is package name.

Android:process = package:remote will run in the package:remote process, which belongs to the global process, and other apps with the same shareUID and signature can run in this process.

Android:process = :remote will run in the default package name: remote process, and it is a private process of the APP, and other APP components are not allowed to access it.

Second: the problems brought by multiple processes.

Static members and singletons fail: each process maintains its own static members and singletons, which are independent of each other.

The thread synchronization mechanism is invalid: each process has its own thread lock.

Reliability of SharedPreferences decreases: concurrent writing is not supported, and dirty data will appear.

Applications are created many times: different processes run on different virtual machines, and each virtual machine will create its own application when it is started, and the life cycle of customizing applications will be chaotic.

To sum up, different processes have their own independent virtual machines, applications and memory spaces, which leads to a series of problems.

Third: Inter-process communication

Binding/Intention Transfer Data:

You can realize the data structure of serializable or packable interfaces through basic types and strings. Serializable is the serialization method of Java, while Parcellable is the serialization method of Android. The former has less code (only one sentence), but the I/O cost is large, and it is generally used to output to disk or network card. The latter realizes more code, high efficiency and serialization and deserialization transmission between general user memory.

File * * * Enjoy:

Read and write the same file successively to realize transmission. Under the Linux mechanism, files can be written concurrently, so pay attention to synchronization. By the way, concurrent reading and writing are not supported under Windows.

Messenger:

Messenger is based on AIDL. The server (passive party) provides a service to handle the connection of the client (active party), maintains a handler to create Messenger, and returns the binder of Messenger when onBind.

Both parties use Messenger to send data and Handler to process data. Messenger relies on handlers to process data, so it is serial. In other words, when a handler receives multiple messages, it queues up to process them in turn.

AIDL:

AIDL defines the public interface of the server and provides it for the client to call. AIDL enables the server to process in parallel, while Messenger can only run serially after encapsulating AIDL, so Messenger is generally used for message delivery.

The interface to be exposed is designed by writing aidl files, which will automatically generate java files after compilation. The server writes the concrete implementation of the interface in Stub and delivers it to the client with iBinder object. When the client binds the service, it restores the iBinder to the interface in the form of asInterface, and then calls its method.

Content provider:

One of the four components of the system, the bottom layer is also Binder implementation, which is mainly used to provide data for other apps. It can be said that it was born for process communication. To realize a ContentProvider by yourself, you need to realize six methods, among which onCreate calls back in the main thread and other methods run in Binder. A user-defined ContentProvider should provide the authorities attribute when registering and wrap it as uri.parse ("content://authorities") when an application needs to access it. You can also set permission, readPermission, and writePermission to set permissions. ContentProvider has methods such as query, deletion and insertion. It seems to be a database management class, but it can actually use files, memory data and so on as data sources. Query returns a cursor, which can be achieved by customizing the class that inherits AbstractCursor.

Socket:

Anyone who has studied computer network is familiar with Socket, so I don't need to elaborate. Just note that Android is not allowed to request the network in the main thread, and you must pay attention to declaring the corresponding permissions when requesting the network. Then the ServerSocket listening port is defined in the server, and the client uses the Socket request port, and communication can be carried out after connection.