本篇文章给大家谈谈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
- @EscBed @EJB中的托管bean会导致java.io.NotSerializableException
- @ViewScoped托管bean中的@EJB导致java.io.NotSerializableException
- android java.io.NotSerializableException
- android-编写Parcelable对象获取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
“ 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)
提前致谢
解决方法
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 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
/ 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
我有一个名为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的相关信息,请在本站查询。
本文标签: