2013-06-04 3 views
0

한 활동에서 다른 활동으로 XMPPConnection 개체를 전달하려고합니다. 저는 Parcelable을 구현하고 HashMap을 사용하여 객체를 저장하는 클래스를 작성했습니다. 의도를 만드는Parcel Map을 사용할 수 없습니다.

class MyParcelable implements Parcelable { 


    Map val=new HashMap<String, XMPPConnection>(); 

    public XMPPConnection getConnection(String s){ 
     return (XMPPConnection) val.get(s); 
    } 

    public void setConnection(String s,XMPPConnection conn){ 
     val.put(s, conn); 
    } 

    MyParcelable() { 

     val=new HashMap<String, XMPPConnection>(); 
    } 

    public MyParcelable(Parcel in) { 
     in.readMap(val, MyParcelable.class.getClassLoader()); 
    } 

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

    @Override 
    public void writeToParcel(Parcel outParcel, int flags) { 

     outParcel.writeMap(val); 
    } 

    public static final Parcelable.Creator<MyParcelable> CREATOR = new Parcelable.Creator<MyParcelable>() { 

     @Override 
     public MyParcelable createFromParcel(Parcel in) { 
      return new MyParcelable(in); 
     } 

     @Override 
     public MyParcelable[] newArray(int size) { 
      return new MyParcelable[size]; 
     } 
    }; 
} 

동안, 나는이 일을 해요 : 여기

내 코드입니다

MyParcelable pr=new MyParcelable(); 
     pr.setConnection("connectionobj", connection); 
     Intent i=new Intent(TestActivity2.this,TestActivity.class); 
     i.putExtra("connection", pr); 
     startActivity(i); 

여분을 가져 오는 동안, 나는이 일을 해요 :

Bundle b = getIntent().getExtras(); 
MyParcelable object = b.getParcelable("connection"); 
this.connection=object.getConnection("connectionobj"); 

하지만 매번 예외가 발생합니다 :

outParcel.writeMap(val); 

예외 : 내가 뭘 잘못 무엇

06-04 16:04:23.443: E/AndroidRuntime(708): FATAL EXCEPTION: main 
06-04 16:04:23.443: E/AndroidRuntime(708): java.lang.RuntimeException: Parcel: unable to marshal value [email protected] 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeValue(Parcel.java:1116) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeMapInternal(Parcel.java:479) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeMap(Parcel.java:463) 
06-04 16:04:23.443: E/AndroidRuntime(708): at com.demo.xmppchat.MyParcelable.writeToParcel(TestActivity2.java:1330) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeParcelable(Parcel.java:1135) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeValue(Parcel.java:1054) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeMapInternal(Parcel.java:479) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Bundle.writeToParcel(Bundle.java:1552) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Parcel.writeBundle(Parcel.java:493) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.content.Intent.writeToParcel(Intent.java:5438) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.app.ActivityManagerProxy.startActivity(ActivityManagerNative.java:1288) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1373) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.app.Activity.startActivityForResult(Activity.java:2817) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.app.Activity.startActivity(Activity.java:2923) 
06-04 16:04:23.443: E/AndroidRuntime(708): at com.demo.xmppchat.TestActivity2.sendmessages(TestActivity2.java:955) 
06-04 16:04:23.443: E/AndroidRuntime(708): at com.demo.xmppchat.IQDepartmentProvider2$1.run(TestActivity2.java:1040) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Handler.handleCallback(Handler.java:587) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Handler.dispatchMessage(Handler.java:92) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.os.Looper.loop(Looper.java:123) 
06-04 16:04:23.443: E/AndroidRuntime(708): at android.app.ActivityThread.main(ActivityThread.java:4627) 
06-04 16:04:23.443: E/AndroidRuntime(708): at java.lang.reflect.Method.invokeNative(Native Method) 
06-04 16:04:23.443: E/AndroidRuntime(708): at java.lang.reflect.Method.invoke(Method.java:521) 
06-04 16:04:23.443: E/AndroidRuntime(708): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
06-04 16:04:23.443: E/AndroidRuntime(708): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
06-04 16:04:23.443: E/AndroidRuntime(708): at dalvik.system.NativeStart.main(Native Method) 

? 모든 입력이 도움이 될 것입니다. 미리 감사드립니다.

답변

2

사랑하는 첫 번째 줄은 명확하게 XMPPConnection이 parcelable isntance없는 문제

06-04 16:04:23.443: E/AndroidRuntime(708): java.lang.RuntimeException: Parcel: unable to marshal value [email protected] 

을 말하고있다. 만약 당신이 수업에서 하나의 물건을 parcelable 다음 다른 일을 parcelable 또는 serializable 인스턴스로 전달할 수 없을거야

+0

내 나쁜 ... 나는 그것을 알아야한다. 그것을 지적 해 주셔서 감사합니다 :) – Abhishek

+0

:) 내 대답을 순위에 의해 고마워 할 수 아무 문제 : D 조 –

관련 문제