ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

android – 为什么parcelable对象在接收活动时为null?

2019-07-26 17:25:56  阅读:158  来源: 互联网

标签:parcelable android android-intent


我遵循Android开发人员指南中的Parcelable示例,目的是让我发送到不同活动的更复杂的对象.现在,我的类是String成员的包装器.如果我将对象放在intent中并从Intent读取它,它会按预期读取,但是,在接收器端,它始终是空指针.

我的课:

package com.mobibob.android.myapp;

import android.os.Parcel;
import android.os.Parcelable;


public class ContentItem implements Parcelable {
    public String name = "name";
    public static final String EXTRA_CONTENT_DETAIL = "contentDetail";

    ContentItem(String n) {
        name = n;
    }

    ContentItem(Parcel in) {
            in.readParcelable(ContentItem.class.getClassLoader());  <--- NEW CODE
        name = in.readString();
    }

    @Override
    public String toString() {
        return name.toString();
    }

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(Parcel dest, int flags) {
        dest.writeString(name);
    }

    public final Parcelable.Creator<ContentItem> CREATOR = new Parcelable.Creator<ContentItem>() {
        public ContentItem createFromParcel(Parcel in) {
        return new ContentItem(in);
        }

        public ContentItem[] newArray(int size) {
        return new ContentItem[size];
        }
    };

}

我的intent / read-back / startActivity设置:

    ContentItem ci = new ContentItem("mobibob");
// Launch ...
Intent i = new Intent(getApplicationContext(), ContentDetailActivity.class);
i.putExtra(ContentItem.EXTRA_CONTENT_DETAIL, ci);
ContentItem readbackCi = i.getParcelableExtra(ContentItem.EXTRA_CONTENT_DETAIL);
Log.d(TAG, "\n\n\t" + readbackCi.name);
startActivity(i);

我的接收活动:

package com.mobibob.android.myapp;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;

public class ContentDetailActivity extends Activity {

    public static final String TAG = "ContentDetailActivity";

    @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
        setContentView(R.layout.content_detail);

        try {
            Intent i = getIntent();
            Log.d(TAG, "intent: " + i.toString());
            Log.d(TAG, "extras: " + i.getExtras());

            ContentItem ci = (ContentItem) i.getParcelableExtra(ContentItem.EXTRA_CONTENT_DETAIL);

            Log.d(TAG, "content-item: " + ci.toString());

            ((TextView) findViewById(R.id.name_of_content)).setText(ci.name);

        } catch (Exception e) {
            Log.d(TAG, e.toString());
    }
    }

}

我的日志:

08-16 15:03:40.121 I/HomeActivity( 9840): onItemClick - AdapterView (pos=1 id=1)
08-16 15:03:40.121 D/HomeActivity( 9840): 
08-16 15:03:40.121 D/HomeActivity( 9840): 
08-16 15:03:40.121 D/HomeActivity( 9840):   Rock/Pop
08-16 15:03:40.131 I/ActivityManager( 1186): Starting activity: Intent { cmp=com.mobibob.android.myapp/.ContentDetailActivity (has extras) }
08-16 15:03:40.341 D/ContentDetailActivity( 9840): intent: Intent { cmp=com.mobibob.android.myapp/.ContentDetailActivity (has extras) }
08-16 15:03:40.341 D/ContentDetailActivity( 9840): extras: Bundle[mParcelledData.dataSize=148]
08-16 15:03:40.351 D/ContentDetailActivity( 9840): java.lang.NullPointerException
08-16 15:03:40.653 I/ActivityManager( 1186): Displayed activity com.mobibob.android.myapp/.ContentDetailActivity: 336 ms (total 336 ms)

我的堆栈回溯:

08-16 17:19:52.170 I/HomeActivity( 3147): onItemClick - AdapterView (pos=3 id=3)
08-16 17:19:52.170 D/HomeActivity( 3147): 
08-16 17:19:52.170 D/HomeActivity( 3147): 
08-16 17:19:52.170 D/HomeActivity( 3147):   mobibob
08-16 17:19:52.170 I/ActivityManager( 1202): Starting activity: Intent { cmp=com.mobibob.android.myapp/.ContentDetailActivity (has extras) }
08-16 17:19:52.410 D/ContentDetailActivity( 3147): intent: Intent { cmp=com.mobibob.android.myapp/.ContentDetailActivity (has extras) }
08-16 17:19:52.410 D/ContentDetailActivity( 3147): extras: Bundle[mParcelledData.dataSize=144]
08-16 17:19:52.410 D/ContentDetailActivity( 3147): java.lang.NullPointerException
08-16 17:19:52.410 W/System.err( 3147): java.lang.NullPointerException
08-16 17:19:52.420 W/System.err( 3147):     at java.lang.reflect.Field.getField(Native Method)
08-16 17:19:52.420 W/System.err( 3147):     at java.lang.reflect.Field.get(Field.java:247)
08-16 17:19:52.420 W/System.err( 3147):     at android.os.Parcel.readParcelable(Parcel.java:1811)
08-16 17:19:52.420 W/System.err( 3147):     at android.os.Parcel.readValue(Parcel.java:1713)
08-16 17:19:52.420 W/System.err( 3147):     at android.os.Parcel.readMapInternal(Parcel.java:1947)
08-16 17:19:52.420 W/System.err( 3147):     at android.os.Bundle.unparcel(Bundle.java:169)
08-16 17:19:52.420 W/System.err( 3147):     at android.os.Bundle.getParcelable(Bundle.java:1037)
08-16 17:19:52.430 W/System.err( 3147):     at android.content.Intent.getParcelableExtra(Intent.java:3276)
08-16 17:19:52.430 W/System.err( 3147):     at com.mobibob.android.myapp.ContentDetailActivity.onCreate(ContentDetailActivity.java:24)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.ActivityThread.access$2200(ActivityThread.java:119)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
08-16 17:19:52.430 W/System.err( 3147):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-16 17:19:52.430 W/System.err( 3147):     at android.os.Looper.loop(Looper.java:123)
08-16 17:19:52.430 W/System.err( 3147):     at android.app.ActivityThread.main(ActivityThread.java:4363)
08-16 17:19:52.430 W/System.err( 3147):     at java.lang.reflect.Method.invokeNative(Native Method)
08-16 17:19:52.430 W/System.err( 3147):     at java.lang.reflect.Method.invoke(Method.java:521)
08-16 17:19:52.430 W/System.err( 3147):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
08-16 17:19:52.430 W/System.err( 3147):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
08-16 17:19:52.440 W/System.err( 3147):     at dalvik.system.NativeStart.main(Native Method)
08-16 17:19:52.895 I/ActivityManager( 1202): Displayed activity com.mobibob.android.myapp/.ContentDetailActivity: 582 ms (total 582 ms)

解决方法:

我猜是in.readParcelable(ContentItem.class.getClassLoader());返回已重新创建的ContentItem.因此,您应该将该行放入Parcelable.Creator中的createFromParcel-Method中.
只是一个猜测.

标签:parcelable,android,android-intent
来源: https://codeday.me/bug/20190726/1545566.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有