首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android java.lang.IllegalArgumentException:在Android2.3中没有字符字段‘指数’

Android java.lang.IllegalArgumentException:在Android2.3中没有字符字段‘指数’
EN

Stack Overflow用户
提问于 2014-01-22 06:24:31
回答 2查看 485关注 0票数 4

我想使用文件系统来存储和检索数据。我的代码在最新版本(如Android4.1和4.4 )中运行良好。但是它不起作用,并且在Android2.3中出现了错误。我从其他类编写对象,对象是Arraylist,并且从同一个类读取对象。请帮帮我。提前谢谢。

下面给出了我的

代码语言:javascript
复制
package com.app.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.text.NumberFormat;
import java.util.HashSet;
import java.util.LinkedHashSet;
import java.util.Map.Entry;
import java.util.Set;

import android.content.Context;
import android.util.Log;

 public final class StorageHelper
 {  
public static Set<String> rec_news = new LinkedHashSet<String>();

public StorageHelper() {
    super();
}

public static void writeObject(Context context, String key, Object object)
        throws IOException, ClassNotFoundException {
    FileOutputStream fos = context.openFileOutput(key, Context.MODE_PRIVATE);
    ObjectOutputStream oos = new ObjectOutputStream(fos);

     /*NumberFormat f = NumberFormat.getInstance(loc);
     if (f instanceof DecimalFormat) {
         ((DecimalFormat) f).setDecimalSeparatorAlwaysShown(true);
     }*/

    //DecimalFormatSymbols s = new DecimalFormatSymbols()

        oos.writeObject(object); // error on this line for android 2.3 //object is Arraylist
    oos.close();
    fos.close();

}

public static Object readObject(Context context, String key)
        throws IOException, ClassNotFoundException {

    FileInputStream fis = context.openFileInput(key);
    ObjectInputStream ois = new ObjectInputStream(fis);
    Object object = ois.readObject();

    return object;
}
}

误差

代码语言:javascript
复制
 01-22 11:29:36.967: E/AndroidRuntime(6733): FATAL EXCEPTION: main
 01-22 11:29:36.967: E/AndroidRuntime(6733): java.lang.IllegalArgumentException: no char field 'exponential'
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.EmulatedFields.put(EmulatedFields.java:459)
  01-22 11:29:36.967: E/AndroidRuntime(6733):   at java.io.EmulatedFieldsForDumping.put(EmulatedFieldsForDumping.java:83)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.text.DecimalFormatSymbols.writeObject(DecimalFormatSymbols.java:591)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.lang.reflect.Method.invokeNative(Native Method)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.lang.reflect.Method.invoke(Method.java:507)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1219)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:1062)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeFields(ObjectOutputStream.java:1008)
  01-22 11:29:36.967: E/AndroidRuntime(6733):   at java.text.DecimalFormat.writeObject(DecimalFormat.java:1215)
  01-22 11:29:36.967: E/AndroidRuntime(6733):   at java.lang.reflect.Method.invokeNative(Native Method)
  01-22 11:29:36.967: E/AndroidRuntime(6733):   at java.lang.reflect.Method.invoke(Method.java:507)
  01-22 11:29:36.967: E/AndroidRuntime(6733):   at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1219)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:1143)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:413)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1241)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1205)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:1143)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:413)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1241)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.util.ArrayList.writeObject(ArrayList.java:651)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.lang.reflect.Method.invokeNative(Native Method)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.lang.reflect.Method.invoke(Method.java:507)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1219)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1575)
 01-22 11:29:36.967: E/AndroidRuntime(6733):    at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1847)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1689)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1653)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at com.app.utils.StorageHelper.writeObject(StorageHelper.java:46)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at  com.app.home.NewsListView.processData(NewsListView.java:359)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at com.app.home.NewsListView.access$4(NewsListView.java:314)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at com.app.home.NewsListView$NewsByIDTask.onPostExecute(NewsListView.java:563)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at com.app.home.NewsListView$NewsByIDTask.onPostExecute(NewsListView.java:1)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at android.os.AsyncTask.finish(AsyncTask.java:417)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at android.os.AsyncTask.access$300(AsyncTask.java:127)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at  android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at android.os.Looper.loop(Looper.java:130)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at android.app.ActivityThread.main(ActivityThread.java:3701)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.lang.reflect.Method.invokeNative(Native Method)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at java.lang.reflect.Method.invoke(Method.java:507)
01-22 11:29:36.967: E/AndroidRuntime(6733):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteI
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-01-22 06:34:40

这被报告为一个bug,您可以看到简短的描述here

编码愉快.:)。

票数 0
EN

Stack Overflow用户

发布于 2014-01-22 06:34:33

在堆栈溢出上进行一些基本的googling提供了以下内容:

Problem serializing DecimalFormatSymbols in 2.3.4

其中,接受的答案解释说,decimalFormat数字必须是final才能序列化。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21275700

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档