为什么 javax.money.CurrencyUnit 不可序列化?

Why is javax.money.CurrencyUnit not Serializable?

为什么 javax.money.CurrencyUnit 不从 java.io.Serializable 扩展?它的所有子类型都实现了 java.io.Serializable,最重要的是,如果你想在你的休眠映射中使用它,那么 findbugs 会阻止你(非常正确),因为:

[INFO] Class com.mycompany.SiteEntity defines non-transient non-serializable instance field defaultCurrency [com.mycompany.SiteEntity] In SiteEntity.java
[INFO] Class com.mycompany.SiteEntity defines non-transient non-serializable instance field supportedCurrencies [com.mycompany.SiteEntity] In SiteEntity.java
[INFO] Class com.mycompany.UserEntity defines non-transient non-serializable instance field sessionCurrency [com.mycompany.UserEntity] In UserEntity.java

这是否意味着必须在休眠映射中使用 class JDKCurrencyAdapter?我更愿意使用界面,但如果不可能,那么我将使用 class.

针对 Serializable 的静态检查在两个方向上都是完全不可靠的。此处的 FindBugs 警告是善意的,但不应阻止您像现在这样使用 CurrencyUnit

一个class可以有一个字段

Object aSerializableObject

并且是可序列化的,即使字段的静态类型不是——只要它确保放置在该字段中的引用是可序列化的。因此针对 Serializable 的静态检查会产生漏报。

它也会产生误报;实施 Serializable 并不能保证实例将毫无例外地序列化;它只是设计意图的陈述。

底线:虽然它伪装成静态类型特征,但可串行化实际上是动态类型特征。静态检查(无论是在代码内,如 <T extends Serializable>,还是外部检查,如这些 FindBugs 警告)只是提示哪里可能出了问题。