【发布时间】:2014-07-24 23:28:14
【问题描述】:
我必须将ArrayList 的BasicNameValuePairs 发送到我的Android 应用程序中的另一个活动。首先它不允许我这样做,说BasicNameValuePair 不可序列化。
所以在阅读了其他一些答案之后,我按照他们的建议制作了我自己的名为 SerializedNameValuePair 的类,它实现了可序列化,并考虑传递一个 ArrayList 。
public class SerializedNameValuePair implements Serializable, NameValuePair{
private BasicNameValuePair nvp;
public SerializedNameValuePair(String name, String value){
nvp=new BasicNameValuePair(name, value);
}
@Override
public String getName() {
return nvp.getName();
}
@Override
public String getValue() {
return nvp.getValue();
}
// serialization support
private static final long serialVersionUID = 1L;
private void writeObject(ObjectOutputStream out) throws IOException {
out.writeChars(nvp.getName());
out.writeChars(nvp.getValue());
}
private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException {
nvp = new BasicNameValuePair(in.readUTF(), in.readUTF());
}
@SuppressWarnings("unused")
private void readObjectNoData() throws ObjectStreamException {
// nothing to do
}
}
然后我为此创建一个ArrayList 并尝试将其传递给Intent。
places 被声明为ShipmentFindingActivity 本身的变量。
ArrayList <SerializedNameValuePair>places;
在AsyncTask 的postExecute 中初始化它。
places=new ArrayList<SerializedNameValuePair>();
然后我在 for 循环中填充 ArrayList。
SerializedNameValuePair nvp=new SerializedNameValuePair(eventname, placename);
places.add(nvp);
有一个按钮首先将其可见性设置为不可见。在postExecute 执行后,它变得可见并且它的onClick 是openMap。
public void openMap(View view){
System.out.println("Map View Button Pressed");
Intent intent=new Intent(context, MapViewingActivity.class);
intent.putExtra("places", places);
startActivity(intent);
}
当我单击按钮时,应用程序在此处崩溃。我在MapViewingActivity 收到这样的意图:
Intent intent=getIntent();
nameValuePairs=(ArrayList<SerializedNameValuePair>) intent.getSerializableExtra("nvp");
当应用程序崩溃时,这就是我在 LogCat 中得到的:
06-04 06:39:13.546: E/AndroidRuntime(2733): FATAL EXCEPTION: main
06-04 06:39:13.546: E/AndroidRuntime(2733): Process: com.example.tradeapp, PID: 2733
06-04 06:39:13.546: E/AndroidRuntime(2733): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.tradeapp/com.example.tradeapp.MapViewingActivity}: java.lang.RuntimeException: Parcelable encountered IOException reading a Serializable object (name = com.example.tradeapp.SerializedNameValuePair)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread.access$800(ActivityThread.java:135)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Handler.dispatchMessage(Handler.java:102)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Looper.loop(Looper.java:136)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread.main(ActivityThread.java:5017)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.lang.reflect.Method.invokeNative(Native Method)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.lang.reflect.Method.invoke(Method.java:515)
06-04 06:39:13.546: E/AndroidRuntime(2733): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
06-04 06:39:13.546: E/AndroidRuntime(2733): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
06-04 06:39:13.546: E/AndroidRuntime(2733): at dalvik.system.NativeStart.main(Native Method)
06-04 06:39:13.546: E/AndroidRuntime(2733): Caused by: java.lang.RuntimeException: Parcelable encountered IOException reading a Serializable object (name = com.example.tradeapp.SerializedNameValuePair)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readSerializable(Parcel.java:2215)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readValue(Parcel.java:2064)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readListInternal(Parcel.java:2343)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readArrayList(Parcel.java:1703)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readValue(Parcel.java:2034)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readArrayMapInternal(Parcel.java:2314)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Bundle.unparcel(Bundle.java:249)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Bundle.getSerializable(Bundle.java:1295)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.content.Intent.getSerializableExtra(Intent.java:4694)
06-04 06:39:13.546: E/AndroidRuntime(2733): at com.example.tradeapp.MapViewingActivity.onCreate(MapViewingActivity.java:38)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.Activity.performCreate(Activity.java:5231)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
06-04 06:39:13.546: E/AndroidRuntime(2733): ... 11 more
06-04 06:39:13.546: E/AndroidRuntime(2733): Caused by: java.io.EOFException
06-04 06:39:13.546: E/AndroidRuntime(2733): at libcore.io.Streams.readFully(Streams.java:83)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.DataInputStream.readFully(DataInputStream.java:99)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.DataInputStream.decodeUTF(DataInputStream.java:178)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.DataInputStream.decodeUTF(DataInputStream.java:173)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.DataInputStream.readUTF(DataInputStream.java:169)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readUTF(ObjectInputStream.java:2113)
06-04 06:39:13.546: E/AndroidRuntime(2733): at com.example.tradeapp.SerializedNameValuePair.readObject(SerializedNameValuePair.java:41)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.lang.reflect.Method.invokeNative(Native Method)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.lang.reflect.Method.invoke(Method.java:515)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readObjectForClass(ObjectInputStream.java:1332)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readHierarchy(ObjectInputStream.java:1244)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readNewObject(ObjectInputStream.java:1833)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readNonPrimitiveContent(ObjectInputStream.java:762)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1981)
06-04 06:39:13.546: E/AndroidRuntime(2733): at java.io.ObjectInputStream.readObject(ObjectInputStream.java:1938)
06-04 06:39:13.546: E/AndroidRuntime(2733): at android.os.Parcel.readSerializable(Parcel.java:2213)
06-04 06:39:13.546: E/AndroidRuntime(2733): ... 23 more
任何想法如何解决?
【问题讨论】:
-
你可以试试 Parcelable
-
@Lollipop 好吧,我不知道那是什么,我会查找并尝试一下。
-
您使用密钥
places传递但使用nvp检索。为什么? -
@kartik 看看这个derekknox.com/daklab/2012/09/05/… Parcellable 比可序列化快 Ref this developerphil.com/parcelable-vs-serializable
-
@Lollipop 嗯...我已经实现了 parcelable 并将所有必需的方法添加到一个名为 ParcelableNVParray 的类中。按照 derekknox 的说法,该类有一个构造函数,它接受一个 Parcel 来初始化数据。我现在如何将我的 ArrayList 存储到这个 Parcel 中??
标签: java android android-intent serialization arraylist