在默认情况下,一个android应用程序只会有一个进程,也就是说所有的activity,service...都是运行在    同一个进程中的,如果不想让它们运行在同一个进程中可用在manifest文件中为它们增加一个process属性。    以activity为例:

1.实现多进程

创建两个activity

MainActivity和SecondActivity

在manifest文件中注册

 <activity  android:name="com.zlb.process.MainActivity" android:process="com.zlb.process.MainActivity" android:label="@string/app_name" >            <intent-filter>                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>        <activity android:name="com.zlb.process.SecondActivity" android:process="com.zlb.process.SecondActivity" ></activity>
启动后打开DDMS会发现有两个进程

2.进程共享数据

    两个进程之间不能直接共享数据,静态变量和单例模式会失效

创建一个类User

public  class User {    static String name;    }

在MainActivity赋值,在SecondActivity取值
MainActivity

User.name="zhangsan";

SecondActivity

System.out.println(User.name);

应用程序报错,去掉process属性正常

创建一个类User1

public class User1 {    private String name;    private static User1 instance =new User1();    public static User1 getinstance(){        return instance;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }
MainActivity
User1.getinstance().setName("lisi");

SecondActivity

System.out.println(User1.getinstance().getName());

应用程序报错,去掉process属性正常

    产生这个现象的原因是因为不同的进程之间是相互隔离的,就android系统而言,每个应用程序都是一个dalvik虚拟机实例,android应用程序被装入    到dalvik虚拟机,对于android4.4之后的版本,应用程序还可以运行在ART(Android RunTime),android的内核是Linux,每个应用程序都会在内核实例    化成一个Linux进程。操作系统会为每个进程单独分配资源,也就是说虽然是静态变量,但在两个进程中都有它的实例,在内存中是两个地址。android    利用Binder实现进程间通信(IPC)。

3.跨进程在应用层的实现

    activity可以使用Intent类来实现,调用系统打电话应用就是一个例子
Intent intent = new Intent(Intent.ACTION_CALL,Uri.parse("tel:"+number));                  startActivity(intent);  
    使用Content Provider可用共享其它应用的数据(返回一个Cursor对象),使用Broadcast可以发送广播。Service通过AIDL实现。    新建一个名为mService.aidl的文件
    package com.zlb.process; interface mService{    void say();}

调用AIDL:

mService service=new mService.Stub() {            @Override            public void say() throws RemoteException {                System.out.println("hello");            }        };        try {            service.say();        } catch (RemoteException e) {            // TODO Auto-generated catch block            e.printStackTrace();        }
    远程调用AIDL只要按照AIDL文件的路径新建包,把AIDL文件放入,直接调用就可以了。

更多相关文章

  1. Android LayoutInflater加载.xml文件原理分析
  2. 利用Android源码工具链直接编译c文件
  3. ffmpeg入门教程之Android使用FFmpeg so(API文件格式转换)
  4. (转载)关于android应用程序的入口Activity
  5. ANDROID对文件的操作
  6. android 进程间的内存分配
  7. android 签名文件获取 MD5、SHA1

随机推荐

  1. android中showSoftInput不起作用
  2. requestWindowFeature使用详解
  3. Android Retrofit 源码系列(一)~ 原理剖析
  4. Android 截图实现
  5. android accessibility
  6. Eclipse下Android-SDK-1.5模拟器启动设置
  7. Android 程序获取、设置铃声、音量、静音
  8. Android(安卓)Studio——layout_weight体
  9. android解决无法设定listview的item高度(
  10. android 4中新增的日历处理相关API