Will any one please tell me what are all the IPC mechanisms that are present in the android.
To my knowledge are:
1) Intents,
2) Binders.
Will any one please tell me what are all the IPC mechanisms that are present in the android.
To my knowledge are:
1) Intents,
2) Binders.
IPC is inter-process communication. It describes the mechanism how different types of android components are communicated.
1) Intents
are messages which components can send and receive. It is a universal mechanism of passing data between processes. With help of the intents one can start services or activities, invoke broadcast receivers and so on.
2) Bundles
are entities the data is passed through. It is similar to the serialization of an object, but much faster on android. Bundle can be got from intent via the getExtras()
method.
3) Binders
are the entity which allows activities and services obtain a reference to another services. It allows not simply send messages to services but directly invoke methods on them.
There are three types of IPC mechanism in Android:
As written on Android Developers page, IPC mechanisms in Android include:
All the answers are good and concise in this post. But i would like to light upon which IPC mechanism should i use. First of all IPC
means Inter Process communication
where two applications or processes will communicate with each other by passing some data between them. Since android is meant for embedded and small devices, we should not use serialization
for IPC
, rather we can use BINDERs
which internally uses parcels
. Parcel
is a sort of light weight serialization by using shared memory concept.
There are many differences between Binder IPC and Serialization IPC:
1. Serialization is very heavy to use in embedded devices, communication will be very slow.
2. Binders uses Parcels to make IPC very fast.
3. Binders internally uses Shared memory concept which uses less memory while sharing data between two processes.
Bottom Line: Binders
uses less memory, and quite fast as it uses parcels. Serialization
is very heavy, takes time to send and receive data, and also it takes more memory compared to binders.
Note: To pass data between activities, services, and receivers use only Bundles. Don't go for either serialization or binders. Binders are specifically used only for binder services where 2 processes will communicate.
Hope this Helps :)
There are three types of the IPC mechanisms: