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)
? 모든 입력이 도움이 될 것입니다. 미리 감사드립니다.
내 나쁜 ... 나는 그것을 알아야한다. 그것을 지적 해 주셔서 감사합니다 :) – Abhishek
:) 내 대답을 순위에 의해 고마워 할 수 아무 문제 : D 조 –