Serializable
和ExternalizableJava
之间有什么区别?
要添加其他答案,可以通过实现java.io.Serializable
,为类的对象获得“自动”序列化功能。无需实现任何其他逻辑,它就可以工作。Java运行时将使用反射来弄清楚如何对你的对象进行封送。
在Java的早期版本中,反射非常慢,因此序列化大型对象图(例如,在客户端-服务器RMI应用程序中)存在一些性能问题。为了处理这种情况,java.io.Externalizable
提供了接口,该接口类似于java.io.Serializable
但具有定制编写的机制来执行编组和解组功能(你需要在类上实现readExternal
和writeExternal
方法)。这为你提供了解决反射性能瓶颈的方法。
在Java的最新版本(当然,从1.3开始)中,反射的性能比以前好得多,因此,这不再是问题。我怀疑Externalizable
使用现代JVM 很难获得有意义的收益。
此外,内置Java序列化机制并不是唯一的机制,你可以获取第三方替代品,例如JBoss序列化,它可以更快地进行,并且是默认替代品。
一个很大的缺点Externalizable
是你必须自己维护此逻辑-如果你在类中添加,删除或更改了一个字段,则必须更改writeExternal/ readExternal
方法来解决这个问题。
总而言之,Externalizable
是Java 1.1的遗物。真的不再需要它了。
本文向大家介绍JAVA序列化Serializable及Externalizable区别详解,包括了JAVA序列化Serializable及Externalizable区别详解的使用技巧和注意事项,需要的朋友参考一下 序列化简介 Java 的对象序列化将那些实现 Serializable 接口的对象转换成一个字节序列,并能在之后将这个字节序列完全恢复为原来的对象。 这就意味着 Java 对象在网络上
问题内容: 我一直认为Java 中的运算符用于验证其两个布尔操作数是否均为,并且该&运算符用于对两种整数类型进行按位运算。 最近我知道,也可以使用运算符来验证其两个布尔操作数是否均为,唯一的区别是即使LHS操作数为false,它也会检查RHS操作数。 Java中的运算符是否在内部重载?还是在这背后有其他概念? 问题答案: <-验证两个操作数 <-停止评估第一个操作数是否为false,因为结果为fa
问题内容: 我只是想知道为什么我们通常在两个布尔之间使用逻辑OR 而不是按位OR ,尽管它们都运行良好。 我的意思是,请看以下内容: 我们可以代替使用吗?与和相同。 问题答案: 如果您使用和形式,而不是这些运算符的和形式,则Java不会费心地单独评估右手操作数。 这是您是否希望缩短评估时间的问题-在 大多数情况 下都是如此。 说明短路好处的一个好方法是考虑以下示例。 正如Jeremy和Peter提
问题内容: 我在看一些模拟的OCJP问题。我遇到了一个非常令人困惑的语法。这里是: 为什么输出在和之间变化? 问题答案: 问题只是和您玩弄混乱的空格。 是通常的(不等于)比较。 另一方面: 最好写成如下形式: 因此,这是两个运算符。 首先反转。 然后将其分配回。 赋值运算符返回分配的值。因此,计算结果为true-这就是您要打印的内容。
问题内容: 我想了解Java中和类型之间的区别,特别是它们与GWT有关。我知道不支持该方法,但是如果需要的话,我需要更多信息。 问题答案: 我不确定GWT因素是否有所不同,但总的来说: 布尔值 是Java基本类型,而 布尔值 是包装布尔值的对象/引用类型 像这样在图元和对象之间进行转换称为装箱/拆箱。 这是更多信息: http://javaeye.wordpress.com/2008/06/17/
问题内容: 和之间有什么区别? 问题答案: 是一个对象,并且是原始数据类型。 有关更多详细信息,请参见此答案。 Double类将原始类型double的值包装在对象中。类型为Double的对象包含单个类型为double的字段。 来源:http : //docs.oracle.com/javase/7/docs/api/java/lang/Double.html