GVKun编程网logo

java.io.NotSerializableException

12

本篇文章给大家谈谈java.io.NotSerializableException,同时本文还将给你拓展@EscBed@EJB中的托管bean会导致java.io.NotSerializableExc

本篇文章给大家谈谈java.io.NotSerializableException,同时本文还将给你拓展@EscBed @EJB中的托管bean会导致java.io.NotSerializableException、@ViewScoped托管bean中的@EJB导致java.io.NotSerializableException、android java.io.NotSerializableException、android-编写Parcelable对象获取java.io.NotSerializableException等相关知识,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

java.io.NotSerializableException

java.io.NotSerializableException

我有这个异常,我不明白为什么会抛出该异常,或者应该如何处理。

try {    os.writeObject(element);} catch (IOException e) {    e.printStackTrace();}

哪里element是一个TransformGroup包含一些其他TransformGroups类的Atom的一个实例:

public class Atom extends Group implements Serializable{    float pozX,pozY;    Group group= new Group();       Color3f blue = new Color3f(new Color(255));    Color3f black = new Color3f(new Color(0));    Sphere AtSph=new Sphere();    public Atom(final float WEIGHT, final int BOUNDS,final float radius,Color3f color)    {        AppSetting ap= new AppSetting(color, black);        AtSph=new Sphere(radius,1,100,ap);    }}

完整的错误日志:

java.io.NotSerializableException: javax.media.j3d.TransformGroup    at java.io.ObjectOutputStream.writeObject0(Unknown Source)    at java.io.ObjectOutputStream.writeObject(Unknown Source)    at cls.MolecularBuilder.addAtom(MolecularBuilder.java:511)    at cls.MolecularBuilder$Console.HidrogenItemActionPerformed(MolecularBuilder.java:897)    at cls.MolecularBuilder$Console$2.actionPerformed(MolecularBuilder.java:746)    at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)    at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)    at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)    at javax.swing.DefaultButtonModel.setPressed(Unknown Source)    at javax.swing.AbstractButton.doClick(Unknown Source)    at javax.swing.plaf.basic.BasicMenuItemUI.doClick(Unknown Source)    at javax.swing.plaf.basic.BasicMenuItemUI$Handler.mouseReleased(Unknown Source)    at java.awt.Component.processMouseEvent(Unknown Source)    at javax.swing.JComponent.processMouseEvent(Unknown Source)    at java.awt.Component.processEvent(Unknown Source)    at java.awt.Container.processEvent(Unknown Source)    at java.awt.Component.dispatchEventImpl(Unknown Source)    at java.awt.Container.dispatchEventImpl(Unknown Source)    at java.awt.Component.dispatchEvent(Unknown Source)    at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)    at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)    at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)    at java.awt.Container.dispatchEventImpl(Unknown Source)    at java.awt.Window.dispatchEventImpl(Unknown Source)    at java.awt.Component.dispatchEvent(Unknown Source)    at java.awt.EventQueue.dispatchEventImpl(Unknown Source)    at java.awt.EventQueue.access$200(Unknown Source)    at java.awt.EventQueue$3.run(Unknown Source)    at java.awt.EventQueue$3.run(Unknown Source)    at java.security.AccessController.doPrivileged(Native Method)    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)    at java.awt.EventQueue$4.run(Unknown Source)    at java.awt.EventQueue$4.run(Unknown Source)    at java.security.AccessController.doPrivileged(Native Method)    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)    at java.awt.EventQueue.dispatchEvent(Unknown Source)    at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)    at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)    at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)    at java.awt.EventDispatchThread.pumpEvents(Unknown Source)    at java.awt.EventDispatchThread.pumpEvents(Unknown Source)    at java.awt.EventDispatchThread.run(Unknown Source)

注意:AppSetting(在Atom类中)只是扩展Appearance的自定义类。

答案1

小编典典

对象的字段又包含其字段,其中某些字段未实现Serializable。就你而言,令人反感的课程是TransformGroup。怎么解决呢?

  • 如果班级是你的,那就上 Serializable
  • 如果班级是第三方,但你不需要序列化形式,请将字段标记为 transient
  • 如果你需要其数据并且是第三方,请考虑其他序列化方式,例如JSON,XML,BSON,MessagePack等,你可以在不修改其定义的情况下序列化第3方对象。

@EscBed @EJB中的托管bean会导致java.io.NotSerializableException

@EscBed @EJB中的托管bean会导致java.io.NotSerializableException

我一直在用@ViewScoped托管bean敲打我的头.我正在使用表单的“schedule”组件来显示一些事件.当用户点击某个特定的按钮时,viewscoped bean中的一个方法是使用ajax调用的,但是每次我得到一个
“ java.io.NotSerializableException”,如果我更改managed-bean范围以请求解决问题.

我究竟做错了什么?有任何想法吗?

这是我的托管bean:

@ManagedBean(name = "schedule")
@ViewScoped
public class ScheduleMBean implements Serializable {

    @EJB
    private CongeBean congeBean;


    @ManagedProperty(value = "#{sessionBean}")
    private SessionMBean sessionBean;

    private DefaultScheduleModel visualiseurConges = null;

    public ScheduleMBean(){

    }
    @postconstruct
    public void init() {

        if(visualiseurConges == null){

                visualiseurConges = new DefaultScheduleModel();
        }



    }

    public void updateSchedule(){

        visualiseurConges.addEvent(new DefaultScheduleEvent("test",new Date(),new Date() ));



    }

    public void setVisualiseurConges(DefaultScheduleModel visualiseurConges) {
        this.visualiseurConges = visualiseurConges;
    }

    public DefaultScheduleModel getVisualiseurConges() {



        return visualiseurConges;
    }

    public void setSessionBean(SessionMBean sessionBean) {
        this.sessionBean = sessionBean;
    }

    public SessionMBean getSessionBean() {
        return sessionBean;
    }



}

这里是全栈跟踪

GRAVE: java.io.NotSerializableException: fr.novae.conseil.gestion.ejb.security.__EJB31_Generated__AuthenticationBean__Intf____Bean__
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1156)
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)
    at java.util.HashMap.writeObject(HashMap.java:1001)
    at sun.reflect.GeneratedMethodAccessor592.invoke(UnkNown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:945)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1461)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)
    at java.io.ObjectOutputStream.writeArray(ObjectOutputStream.java:1338)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1146)
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)
    at java.util.HashMap.writeObject(HashMap.java:1001)
    at sun.reflect.GeneratedMethodAccessor592.invoke(UnkNown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:945)
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1461)
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)
    at com.sun.faces.renderkit.ClientSideStateHelper.doWriteState(ClientSideStateHelper.java:293)
    at com.sun.faces.renderkit.ClientSideStateHelper.writeState(ClientSideStateHelper.java:167)
    at com.sun.faces.renderkit.ResponseStateManagerImpl.writeState(ResponseStateManagerImpl.java:123)
    at com.sun.faces.application.StateManagerImpl.writeState(StateManagerImpl.java:155)
    at org.primefaces.application.PrimeFacesPhaseListener.writeState(PrimeFacesPhaseListener.java:174)
    at org.primefaces.application.PrimeFacesPhaseListener.handleAjaxRequest(PrimeFacesPhaseListener.java:111)
    at org.primefaces.application.PrimeFacesPhaseListener.beforePhase(PrimeFacesPhaseListener.java:74)
    at com.sun.faces.lifecycle.Phase.handleBeforePhase(Phase.java:228)
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:99)
    at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:313)
    at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1523)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:279)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:188)
    at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:641)
    at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:97)
    at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:85)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:185)
    at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:325)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:226)
    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:165)
    at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:791)
    at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:693)
    at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:954)
    at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:170)
    at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:135)
    at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:102)
    at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:88)
    at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:76)
    at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:53)
    at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:57)
    at com.sun.grizzly.ContextTask.run(ContextTask.java:69)
    at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:330)
    at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:309)
    at java.lang.Thread.run(Thread.java:619)

提前致谢

解决方法

@ViewScoped bean存储在HTTP会话中.存储在HTTP会话中的任何对象都需要实现 Serializable.另请参见 JSF managed bean causing java.io.NotSerializableException during Tomcat deployment和 java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException.

NotSerializableException通常是自解释的,因为它提到了需要序列化的类的完整限定名,但不能因为它不实现Serializable.

然而,在这种特殊情况下,这个名称似乎表示一个自动生成的类,很可能由EJB容器自动生成,因此完全脱离了你的控制.

我以前从来没有看到这个问题,Google似乎也没有太多关于这个问题.基于stacktrace,你使用的是Glassfish v3,所以我建议发布一个issue.同时您最好的选择是将JSF视图状态设置为服务器端.

更新:MyFaces中的类似问题表明在反序列化期间使用错误的类加载器的JSF impl具体问题.升级JSF impl应该可以解决问题:@EJB in @ViewScoped @ManagedBean causes java.io.NotSerializableException.

@ViewScoped托管bean中的@EJB导致java.io.NotSerializableException

@ViewScoped托管bean中的@EJB导致java.io.NotSerializableException

我一直在用@ViewScoped Managed-Bean来敲打我的头。我正在使用primeface的“计划”组件以显示一些事件。当用户单击特定按钮时,使用ajax在viewscoped bean中调用一个方法,但是每次我得到一个“ java.io.NotSerializableException”时,如果我更改托管bean范围以请求该问题,就会消失。

我究竟做错了什么?有任何想法吗?

这是我的托管bean:

@ManagedBean(name = "schedule")@ViewScopedpublic class ScheduleMBean implements Serializable {    @EJB    private CongeBean congeBean;    @ManagedProperty(value = "#{sessionBean}")    private SessionMBean sessionBean;    private DefaultScheduleModel visualiseurConges = null;    public ScheduleMBean(){    }    @PostConstruct    public void init() {        if(visualiseurConges == null){                visualiseurConges = new DefaultScheduleModel();        }    }    public void updateSchedule(){        visualiseurConges.addEvent(new DefaultScheduleEvent("test" , new Date(), new Date() ));    }    public void setVisualiseurConges(DefaultScheduleModel visualiseurConges) {        this.visualiseurConges = visualiseurConges;    }    public DefaultScheduleModel getVisualiseurConges() {        return visualiseurConges;    }    public void setSessionBean(SessionMBean sessionBean) {        this.sessionBean = sessionBean;    }    public SessionMBean getSessionBean() {        return sessionBean;    }}

这是全栈跟踪

GRAVE: java.io.NotSerializableException: fr.novae.conseil.gestion.ejb.security.__EJB31_Generated__AuthenticationBean__Intf____Bean__    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1156)    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)    at java.util.HashMap.writeObject(HashMap.java:1001)    at sun.reflect.GeneratedMethodAccessor592.invoke(Unknown Source)    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)    at java.lang.reflect.Method.invoke(Method.java:597)    at java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:945)    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1461)    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1509)    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1474)    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)    at java.io.ObjectOutputStream.writeArray(ObjectOutputStream.java:1338)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1146)    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)    at java.util.HashMap.writeObject(HashMap.java:1001)    at sun.reflect.GeneratedMethodAccessor592.invoke(Unknown Source)    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)    at java.lang.reflect.Method.invoke(Method.java:597)    at java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:945)    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1461)    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1392)    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1150)    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:326)    at com.sun.faces.renderkit.ClientSideStateHelper.doWriteState(ClientSideStateHelper.java:293)    at com.sun.faces.renderkit.ClientSideStateHelper.writeState(ClientSideStateHelper.java:167)    at com.sun.faces.renderkit.ResponseStateManagerImpl.writeState(ResponseStateManagerImpl.java:123)    at com.sun.faces.application.StateManagerImpl.writeState(StateManagerImpl.java:155)    at org.primefaces.application.PrimeFacesPhaseListener.writeState(PrimeFacesPhaseListener.java:174)    at org.primefaces.application.PrimeFacesPhaseListener.handleAjaxRequest(PrimeFacesPhaseListener.java:111)    at org.primefaces.application.PrimeFacesPhaseListener.beforePhase(PrimeFacesPhaseListener.java:74)    at com.sun.faces.lifecycle.Phase.handleBeforePhase(Phase.java:228)    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:99)    at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:139)    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:313)    at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1523)    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:279)    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:188)    at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:641)    at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:97)    at com.sun.enterprise.web.PESessionLockingStandardPipeline.invoke(PESessionLockingStandardPipeline.java:85)    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:185)    at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:325)    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:226)    at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:165)    at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:791)    at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:693)    at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:954)    at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:170)    at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:135)    at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:102)    at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:88)    at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:76)    at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:53)    at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:57)    at com.sun.grizzly.ContextTask.run(ContextTask.java:69)    at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:330)    at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:309)    at java.lang.Thread.run(Thread.java:619)

提前致谢

答案1

小编典典

@ViewScopedbean存储在HTTP会话中。HTTP会话中存储的所有对象都需要实现Serializable。另请参见在Tomcat部署期间导致java.io.NotSerializableException的JSF受管bean和java.io.WriteAbortedException:编写中止;java.io.NotSerializableException

NotSerializableException通常,这是不言自明的,因为它提到了也需要序列化的类的完全限定名称,但是由于没有实现而不能这样Serializable。

但是,在这种特殊情况下,名称似乎表示一个自动生成的类,很可能是由EJB容器自动生成的,因此完全不受您的控制。

我以前从未见过此问题,并且Google似乎也没有对此问题提供太多帮助。基于您正在使用Glassfish v3的stacktrace,所以我建议发布有关此问题。同时,最好的选择是将JSF视图状态保存设置为服务器端。

更新:MyFaces中的类似问题表明,JSF暗示了反序列化期间使用错误的类加载器的特定问题。升级JSF impl应该可以解决问题:@ViewScoped @ManagedBean中的@EJB导致java.io.NotSerializableException。

android java.io.NotSerializableException

android java.io.NotSerializableException

/ CRASH: co.zuren.rent (pid 8857)

// Short Msg: java.io.NotSerializableException

// Long Msg: java.io.NotSerializableException: android.widget.FrameLayout

// Build Label: Xiaomi/2014011/HM2014011:4.2.2/HM2014011/JHFCNBL27.0:user/release-keys

// Build Changelist: JHFCNBL27.0

// Build Time: 1422850989000

// java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = co.zuren.rent.controller.activity.PublishDateSecondActivity$1)

// at android.os.Parcel.writeSerializable(Parcel.java:1279)

// at android.os.Parcel.writeValue(Parcel.java:1233)

// at android.os.Parcel.writeMapInternal(Parcel.java:591)

// at android.os.Bundle.writeToParcel(Bundle.java:1627)

// at android.os.Parcel.writeBundle(Parcel.java:605)

// at android.support.v4.app.FragmentState.writeToParcel(Fragment.java:132)

// at android.os.Parcel.writeTypedArray(Parcel.java:1102)

// at android.support.v4.app.FragmentManagerState.writeToParcel(FragmentManager.java:374)

// at android.os.Parcel.writeParcelable(Parcel.java:1254)

// at android.os.Parcel.writeValue(Parcel.java:1173)

// at android.os.Parcel.writeMapInternal(Parcel.java:591)

// at android.os.Bundle.writeToParcel(Bundle.java:1627)

// at android.os.Parcel.writeBundle(Parcel.java:605)

// at android.app.ActivityManagerProxy.activityStopped(ActivityManagerNative.java:2308)

// at android.app.ActivityThread$StopInfo.run(ActivityThread.java:3303)

// at android.os.Handler.handleCallback(Handler.java:800)

// at android.os.Handler.dispatchMessage(Handler.java:100)

// at android.os.Looper.loop(Looper.java:194)

// at android.app.ActivityThread.main(ActivityThread.java:5433)

// at java.lang.reflect.Method.invokeNative(Native Method)

// at java.lang.reflect.Method.invoke(Method.java:525)

// at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:853)

// at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)

// at dalvik.system.NativeStart.main(Native Method)

// Caused by: java.io.NotSerializableException: android.widget.FrameLayout

// at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1364)

// at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)

// at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:979)

// at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:368)

// at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1074)

// at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1404)

// at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)

// at java.io.ObjectOutputStream.writeFieldValues(ObjectOutputStream.java:979)

// at java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:368)

// at java.io.ObjectOutputStream.writeHierarchy(ObjectOutputStream.java:1074)

// at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1404)

// at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)

// at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1481)

// at android.os.Parcel.writeSerializable(Parcel.java:1274)





PublishDateSecondActivity.java 已经序列化过了,他说FrameLayout是怎么回事?

android-编写Parcelable对象获取java.io.NotSerializableException

android-编写Parcelable对象获取java.io.NotSerializableException

我有一个名为Shop的类,它具有2个字段和1个静态字段.该类实现Parcelable接口:

public class Shop implements Parcelable{
   private static int SHOP_ID = 12;

   private String name;
   private long fund;

   //constructor with parcel
   public Shop(Parcel parcel){
       name = parcel.readString();
       fund = parcel.readLong();
   }

   //normal constructor
   public Shop(Owner owner){
        name = owner.getShopName();
        fund = owner.getFund();
    }

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

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

    public static final Creator<Shop> CREATOR = new Creator<Shop>(){

       @Override
       public Shop createFromParcel(Parcel parcel) {
        //use the constructor which accept parcel
        return new Shop(parcel);
       }

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

    };
}

现在,我的代码通过使用常规构造函数启动Shop实例:

Owner owner = getownerInfo();
Shop myShop = new Shop(owner); //initiate a Shop with owner

然后,我的代码将shop实例存储到Android的内部存储中:

String fileName = "shop_file";
try{
  FileOutputStream fos = activity.openFileOutput(fileName,Context.MODE_PRIVATE);
  ObjectOutputStream oos = new ObjectOutputStream(fos);         

  oos.writeObject(myShop); 
  oos.flush();
  oos.close();
}catch(Exception ex){
  ...
}

但是当运行我的应用程序时,我得到了java.io.NotSerializableException:

06-12 13:04:29.258: W/System.err(2632): java.io.NotSerializableException: com.my.app.model.Shop
06-12 13:04:29.258: W/System.err(2632):     at java.io.ObjectOutputStream.writeNewObject(ObjectOutputStream.java:1364)
06-12 13:04:29.266: W/System.err(2632):     at java.io.ObjectOutputStream.writeObjectInternal(ObjectOutputStream.java:1671)
06-12 13:04:29.266: W/System.err(2632):     at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:1517)

为什么?我哪里错了?

解决方法:

从执行看来,您正在尝试序列化未实现Serializable的CartData实例:

java.io.NotSerializableException: com.my.app.model.Shop

如果要序列化,则应让Shop implemensts Serializable

从doc开始

Parcel is not a general-purpose serialization mechanism. This class
(and the corresponding Parcelable API for placing arbitrary objects
into a Parcel) is designed as a high-performance IPC transport. As
such, it is not appropriate to place any Parcel data in to persistent
storage: changes in the underlying implementation of any of the data
in the Parcel can render older data unreadable.

我们今天的关于java.io.NotSerializableException的分享已经告一段落,感谢您的关注,如果您想了解更多关于@EscBed @EJB中的托管bean会导致java.io.NotSerializableException、@ViewScoped托管bean中的@EJB导致java.io.NotSerializableException、android java.io.NotSerializableException、android-编写Parcelable对象获取java.io.NotSerializableException的相关信息,请在本站查询。

本文标签: