因为不同进程都是享有独立资源的,所以全局变量这些都是无效的,必须有其他的进程间通信方式。

一、基本知识

1:怎样使用多进程

Android正常使用的多进程的办法只有一种,就是在Service或Activity的属性里面设置remote属性

这样,我们打开Main2Activty的时候,该活动或服务就会以一个新的进程来创建

2:查看进程信息

通过adb shell连接上我们的手机,输入ps命令,查看所有的进程

可以使用ps|grep命令 + 包名 直接查看我们的app的进程信息   这里的grep是查询文本的命令

可以看到,有两个不同的进程。第一个是我们的MainActivity,没有指定属性,默认进程名是包名。第二是Main2Activity,默认是包名+:remote

3:对象的序列化

3.1:什么是序列化?

简单点来说,序列化就是把我们包含了数据的对象,转化成一堆数据,保存在文件中。

3.2:序列化的作用?

(1).永久的保存对象数据(将对象数据保存在文件当中,或者是磁盘中

(2).通过序列化操作将对象数据在网络上进行传输(由于网络传输是以字节流的方式对数据进行传输的.因此序列化的目的是将对象数据转换成字节流的形式)

(3).将对象数据在进程之间进行传递(Activity之间传递对象数据时,需要在当前的Activity中对对象数据进行序列化操作.在另一个Activity中需要进行反序列化操作讲数据取出)

(4).Java平台允许我们在内存中创建可复用的Java对象,但一般情况下,只有当JVM处于运行时,这些对象才可能存在,即,这些对象的生命周期不会比JVM的生命周期更长(即每个对象都在JVM中)但在现实应用中,就可能要停止JVM运行,但有要保存某些指定的对象,并在将来重新读取被保存的对象。这是Java对象序列化就能够实现该功能。(可选择入数据库、或文件的形式保存)

(5).序列化对象的时候只是针对变量进行序列化,不针对方法进行序列化.

(6).在Intent之间,基本的数据类型直接进行相关传递即可,但是一旦数据类型比较复杂的时候,就需要进行序列化操作了.

可以简单的理解为,转化为数据流之后,方便计算机直接传数据或保存数据。

3.3:怎么序列化

自定义的类必须实现 Serializable 或者 Parcelable 接口

3.3.1:Serializable

这是Java提供的一个序列化的接口,非常简单,只需自行声明一个版本ID即可,其他的都已经封装好了。

//自定义类

public class SerialUser implements Serializable {

    //版本号
private static final long serialVersionUID = 2016L; //成员
String name;
int age; //构造函数
public SerialUser(String name,int age){ this.name = name;
this.age = age; }
}

//序列化过程 MainActivity

public class MainActivity extends AppCompatActivity {

    Button button;

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); button = (Button)findViewById(R.id.button); //使用序列化的类
//序列化过程
SerialUser user = new SerialUser("小明",20);
try { File file = new File(Environment.getExternalStorageDirectory()
+ "/my.txt"); ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(file));
out.writeObject(user);
out.close(); } catch (IOException e) {
Log.d("TAG",e.toString());
} button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) { Intent intent = new Intent(MainActivity.this,Main2Activity.class);
startActivity(intent); }
}); }
}

//反序列化过程 Main2Activity

public class Main2Activity extends AppCompatActivity {

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2); Log.d("TAG","new process"); //反序列化的过程
try { File file = new File(Environment.getExternalStorageDirectory()
+ "/my.txt"); ObjectInputStream in = new ObjectInputStream(new FileInputStream(file));
SerialUser user = (SerialUser)in.readObject();
in.close();
Log.d("TAG","ok");
Log.d("TAG",user.name+user.age); } catch (IOException e) {
Log.d("TAG",e.toString());
} catch (ClassNotFoundException e) {
Log.d("TAG",e.toString());
} }
}

效果图

顺便看看中间文件my.txt里面到底存了什么数据

3.3.2:Parcelable

Parcelable不像Serialable那样,可以直接指定中间文件。所以反序列化时不能够通过打开文件读取的方式来进行。

我们要实现完整Parcelable接口就行了。Parcelable一般是通过Intent使用的,放进Intent里面来传递数据。

public class ParcelUser implements Parcelable {

    //成员
String name;
String sex;
int age; //构造
public ParcelUser(String name,String sex,int age){ this.name = name; this.sex = sex; this.age = age; } //一般都是返回0,不用管
@Override
public int describeContents() {
return 0;
} //必须实现的
//其实只是针对成员变量保存一下就好
@Override
public void writeToParcel(Parcel dest, int flags) { dest.writeString(name);
dest.writeString(sex);
dest.writeInt(age); } //反序列化,这个地方系统没有提供来实现,自己要补上
//该实现的地方都实现就对了
public static final Parcelable.Creator<ParcelUser> CREATOR = new Creator<ParcelUser>() {
@Override
public ParcelUser createFromParcel(Parcel source) {
return new ParcelUser(source );
} @Override
public ParcelUser[] newArray(int size) {
return new ParcelUser[size];
}
}; //反序列化的构造函数
private ParcelUser(Parcel in){ this.name = in.readString();
this.sex = in.readString();
this.age = in.readInt(); } }

MainActivity:

public class MainActivity extends AppCompatActivity {

    Button button;

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); button = (Button)findViewById(R.id.button); button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) { Intent intent = new Intent(MainActivity.this,Main2Activity.class); ParcelUser user = new ParcelUser("小红","女",16); intent.putExtra("user",user); startActivity(intent); }
}); }
}

Main2Activity:

public class Main2Activity extends AppCompatActivity {

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2); Log.d("TAG", "new process"); //反序列化的过程
Intent intent = getIntent(); ParcelUser user = intent.getParcelableExtra("user"); Log.d("TAG",user.name);
Log.d("TAG",user.sex);
Log.d("TAG",user.age+""); } }

Android六大进程间通信方式总结之一:基本知识的更多相关文章

  1. 国内Android应用推广的六大主流方式

    国内Android应用推广的六大主流方式 http://mobi.baike.com/article-19433.html 随着Android市场份额的飞速增长,越来越多的国内开发团队和公司開始投入A ...

  2. 最快的进程间通信方式你get了么

    前言:天下武功为快不破!在信息爆炸.快速发展的新时代...,扯远了....进程间通信方式有很多,但最快的方式你知道么?由我娓娓道来... 一.共享内存方式 主角闪亮登场了,噔噔瞪...,最快的方式就是 ...

  3. Android六大基本布局

    一.基本理论Android六大基本布局分别是:线性布局LinearLayout.表格布局TableLayout.相对布局RelativeLayout.层布局FrameLayout.绝对布局Absolu ...

  4. 每个Android开发者必须知道的内存管理知识

    原文:每个Android开发者必须知道的内存管理知识 拷贝在此处,以备后续查看. 相信一步步走过来的Android从业者,每个人都会遇到OOM的情况.如何避免和防范OOM的出现,对于每一个程序员来说确 ...

  5. Android开发——进程间通信之AIDL(二)

    0.  前言 不论是Android还是其它操作系统.都会有自己的IPC机制.所谓IPC(Inter-Process Communication)即进程间通信.首先线程和进程是非常不同的概念,线程是CP ...

  6. Android数据存储方式--SharedPreferences

    Android数据存储方式有如下四种:SharedPreferences.存储到文件.SQLite数据库.内容提供者(Content provider).存储到网络服务器. 本文主要介绍一下Share ...

  7. 在android用Get方式发送http请求

    烦人的日子终于过去啦,终于又可以写博客啦,对自己的android学习做个总结,方便以后查看...... 一.在android用Get方式发送http请求,使用的是java标准类,也比较简单. 主要分以 ...

  8. Android 采用post方式提交数据到服务器

    接着上篇<Android 采用get方式提交数据到服务器>,本文来实现采用post方式提交数据到服务器 首先对比一下get方式和post方式: 修改布局: <LinearLayout ...

  9. Android+struts2+JSON方式的手机开发(Login)

    在手机的后台服务无论是调用WebService还是Http请求,多数都是采用Android的HttpClient实现相关的调用实现.本文实现Android+Struts2+JSON方式实现为手机前台提 ...

随机推荐

  1. 原生js实现div拖拽+按下鼠标计时

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <style> ...

  2. linux自学(一)之vmware虚拟机安装

    之前有研究过linux,后来一段时间没有操作了,现在有点陌生,而且当初也没有记录学习内容.现在想从新开始包括虚拟机安装到部署Javaweb项目,把这之间所需要的全都记录下来,以便后边学习参考使用. 虚 ...

  3. BZOJ2821 作诗(Poetize) 【分块】

    BZOJ2821 作诗(Poetize) Description 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好是作诗. 由于时间紧迫,SHY作完诗之后还要虐OI ...

  4. KeyDown/PreviewKeyDown事件中监听Alt键按下

    一个坑 在WPF应用程序(或者其他Windows应用程序中),为了监听Alt键按下,我们可以尝试写出这样的代码: PreviewKeyDown += (s, e) => { if (e.Key ...

  5. Python面试题(十一)

    1.Python中list.tuple.dict.set有什么区别,主要应用在什么样的场景?并用for语句分别进行遍历 定义: list:链表,有序的项目, 通过索引进行查找,使用方括号”[]”; t ...

  6. python: find the index of a given value in a list

    ["foo", "bar", "baz"].index("bar")

  7. Kalman Filter

    本质是一种最优估计法.  核心是"预测"+"测量反馈". 一个视频: http://blog.sina.com.cn/s/blog_461db08c0102uw ...

  8. docker swarm mode routing mesh 使用

    Docker Engine swarm mode makes it easy to publish ports for services to make them available to resou ...

  9. hashids 了解

    用于隐藏真实的id 原理是从数字经过一个加盐(salted)算法产生一个哈希(hash)字符串.这样算法就是通过混淆使结果具有不可预测性,而唯一性依然由数字本身来达成,从而得到(类似 youtube ...

  10. Docker生态不会重蹈Hadoop的覆辙

    本文原作者是晏东(精灵云Ghostcould创始人),在读到<Docker生态会重蹈Hadoop的覆辙吗?>文章后的个人思考,里面的不少观点也是很不错的. 1.形态上的差异 2013年的时 ...