探索Android中的Parcel机制(下)

2024-01-07 10:08
文章标签 android 探索 机制 parcel

本文主要是介绍探索Android中的Parcel机制(下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.csdn.net/caowenbin/article/details/6532238


  上一篇中我们透过源码看到了Parcel背后的机制,本质上把它当成一个Serialize就可以了,只是它是在内存中完成的序列化和反序列化,利用的是连续的内存空间,因此会更加高效。

         我们接下来要说的是Parcel类如何应用。就应用程序而言,最常见使用Parcel类的场景就是在Activity间传递数据。没错,在Activity间使用Intent传递数据的时候,可以通过Parcelable机制传递复杂的对象。

         在下面的程序中,MyColor用于保存一个颜色值,MainActivity在用户点击屏幕时将MyColor对象设成红色,传递到SubActivity中,此时SubActivity的TextView显示为红色的背景;当点击SubActivity时,将颜色值改为绿色,返回MainActivity,期望的是MainActivity的TextView显示绿色背景。

         来看一下MyColor类的实现代码:

    package com.wenbin.test;  import android.graphics.Color;  import android.os.Parcel;  import android.os.Parcelable;  /** * @author 曹文斌 * http://blog.csdn.net/caowenbin * */  public class MyColor implements Parcelable {  private int color=Color.BLACK;  MyColor(){  color=Color.BLACK;  }  MyColor(Parcel in){  color=in.readInt();  }  public int getColor(){  return color;  }  public void setColor(int color){  this.color=color;  }  @Override  public int describeContents() {  return 0;  }  @Override  public void writeToParcel(Parcel dest, int flags) {  dest.writeInt(color);  }  public static final Parcelable.Creator<MyColor> CREATOR  = new Parcelable.Creator<MyColor>() {  public MyColor createFromParcel(Parcel in) {  return new MyColor(in);  }  public MyColor[] newArray(int size) {  return new MyColor[size];  }  };  }  

 

         该类实现了Parcelable接口,提供了默认的构造函数,同时也提供了可从Parcel对象开始的构造函数,另外还实现了一个static的构造器用于构造对象和数组。代码很简单,不一一解释了。

         再看MainActivity的代码:

    package com.wenbin.test;  import android.app.Activity;  import android.content.Intent;  import android.graphics.Color;  import android.os.Bundle;  import android.view.MotionEvent;  /** * @author 曹文斌 * http://blog.csdn.net/caowenbin * */  public class MainActivity extends Activity {  private final int SUB_ACTIVITY=0;  private MyColor color=new MyColor();  @Override  public void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.main);  }  @Override  protected void onActivityResult(int requestCode, int resultCode, Intent data) {  super.onActivityResult(requestCode, resultCode, data);  if (requestCode==SUB_ACTIVITY){  if (resultCode==RESULT_OK){  if (data.hasExtra("MyColor")){  color=data.getParcelableExtra("MyColor");  //Notice  findViewById(R.id.text).setBackgroundColor(color.getColor());  }  }  }  }  @Override  public boolean onTouchEvent(MotionEvent event){  if (event.getAction()==MotionEvent.ACTION_UP){  Intent intent=new Intent();  intent.setClass(this, SubActivity.class);  color.setColor(Color.RED);  intent.putExtra("MyColor", color);  startActivityForResult(intent,SUB_ACTIVITY);      }  return super.onTouchEvent(event);  }  }  

 

        下面是SubActivity的代码:

 

    package com.wenbin.test;  import android.app.Activity;  import android.content.Intent;  import android.graphics.Color;  import android.os.Bundle;  import android.view.MotionEvent;  import android.widget.TextView;  /** * @author 曹文斌 * http://blog.csdn.net/caowenbin * */  public class SubActivity extends Activity {  private MyColor color;  @Override  public void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.main);  ((TextView)findViewById(R.id.text)).setText("SubActivity");  Intent intent=getIntent();  if (intent!=null){  if (intent.hasExtra("MyColor")){  color=intent.getParcelableExtra("MyColor");  findViewById(R.id.text).setBackgroundColor(color.getColor());  }  }  }  @Override  public boolean onTouchEvent(MotionEvent event){  if (event.getAction()==MotionEvent.ACTION_UP){  Intent intent=new Intent();  if (color!=null){  color.setColor(Color.GREEN);  intent.putExtra("MyColor", color);  }  setResult(RESULT_OK,intent);  finish();  }  return super.onTouchEvent(event);  }  }  

 

        下面是main.xml的代码:

    <?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:orientation="vertical"  android:layout_width="fill_parent"  android:layout_height="fill_parent"  >  <TextView    android:layout_width="fill_parent"   android:layout_height="wrap_content"   android:text="@string/hello"  android:id="@+id/text"  />  </LinearLayout>  

 

        注意的是在MainActivity的onActivityResult()中,有一句color=data.getParcelableExtra("MyColor"),这说明的是反序列化后是一个新的MyColor对象,因此要想使用这个对象,我们做了这个赋值语句。

         记得在上一篇《探索Android中的Parcel机制(上)》中提到,如果数据本身是IBinder类型,那么反序列化的结果就是原对象,而不是新建的对象,很显然,如果是这样的话,在反序列化后在MainActivity中就不再需要color=data.getParcelableExtra("MyColor")这句了。因此,换一种MyColor的实现方法,令其中的int color成员变量使用IBinder类型的成员变量来表示。

         新建一个BinderData类继承自Binder,代码如下:

 

    package com.wenbin.test;  import android.os.Binder;  /** * @author 曹文斌 * http://blog.csdn.net/caowenbin * */  public class BinderData extends Binder {  public int color;  }  

  

       修改MyColor的代码如下:


    package com.wenbin.test;  import android.graphics.Color;  import android.os.Parcel;  import android.os.Parcelable;  /** * @author 曹文斌 * http://blog.csdn.net/caowenbin * */  public class MyColor implements Parcelable {  private BinderData data=new BinderData();  MyColor(){  data.color=Color.BLACK;  }  MyColor(Parcel in){  data=(BinderData) in.readValue(BinderData.class.getClassLoader());  }  public int getColor(){  return data.color;  }  public void setColor(int color){  data.color=color;  }  @Override  public int describeContents() {  return 0;  }  @Override  public void writeToParcel(Parcel dest, int flags) {  dest.writeValue(data);  }  public static final Parcelable.Creator<MyColor> CREATOR  = new Parcelable.Creator<MyColor>() {  public MyColor createFromParcel(Parcel in) {  return new MyColor(in);  }  public MyColor[] newArray(int size) {  return new MyColor[size];  }  };  }  

         去掉MainActivity的onActivityResult()中的color=data.getParcelableExtra("MyColor")一句,变成:

 

    @Override  protected void onActivityResult(int requestCode, int resultCode, Intent data) {  super.onActivityResult(requestCode, resultCode, data);  if (requestCode==SUB_ACTIVITY){  if (resultCode==RESULT_OK){  if (data.hasExtra("MyColor")){  findViewById(R.id.text).setBackgroundColor(color.getColor());  }  }  }  }  

         再次运行程序,结果符合预期。

 

         以上就是Parcel在应用程序中的使用方法,与Serialize还是挺相似的,详细的资料当然还是要参考Android SDK的开发文档了。

——欢迎转载,请注明出处 http://blog.csdn.net/caowenbin ——



这篇关于探索Android中的Parcel机制(下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/579561

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

【Tools】大模型中的自注意力机制

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 自注意力机制(Self-Attention)是一种在Transformer等大模型中经常使用的注意力机制。该机制通过对输入序列中的每个元素计算与其他元素之间的相似性,

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动