Serializable
класс имеет цепочку родителей, пока эти родители тоже Serializable
, десериализация объекта идет от родителя к наследнику, в обход конструктора. Вместо него вызываются методы readObject
(readObjectNoData
). Но как только встречается первый предок, не реализующий интерфейс Serializable
, инициализация для него возвращается в нормальное русло – вместо readObject
вызывается конструктор без аргументов. Если такого конструктора нет, или он объявлен private
, исполнение выбросит InvalidClassException
.При сериализации несериализуемые предки просто игнорируются.
Если класс несериализуемый и не предоставляет достаточного доступа к своему логическому состоянию для наследников, правильно реализовать его наследника сериализуемым может быть невозможно.
Популярный вопрос на тему – как когда сериализуешь объект класса-наследника, избежать сериализации его родительской части. Единственный способ добиться этого – кастомизировать сериализационную форму, определив собственную реализацию
writeObject()
, либо используя интерфейс Externalizable
.Открытость класса для наследования делает неприменимым паттерн serialization proxy (который рассмотрим позднее).