Я пытаюсь отправить объекты из пакетов через выделенный пакет связи в другую среду. Для связи я использую стандартную сериализацию Java (с ObjectStreams) через TCP / IP.
Поток связи следующий: пакет отправителя будет передавать сериализуемые объекты отправителю-отправителю, который будет сериализовывать объекты и отправлять их через TCP / IP передающему-получателю. Затем получатель десериализует полученные объекты и передает их в связку получателя.
Поскольку архитектура загрузки классов OSGi отличается от нативной, я должен сделать небольшой взлом с помощью загрузчика классов: так как я предполагаю, что пакет-получатель должен знать классы, которые он получает (= импортировал их или иным образом доступ его загрузчик классов), я использую загрузчик классов приемника вместо передающего приемника для загрузки класса. (С помощью метода Bundle.loadClass (..)).
Это хорошо работает для пользовательских классов, однако, это не работает для массивов пользовательских типов.
(Которые не известны загрузчику классов передатчик-приемник, но пакету приемника.)
Редактировать: ObjectInputStream.readObject (...) генерирует исключение ClassNotFoundException, если оно пытается десериализовать массив. (Я предполагаю, что это исключение происходит из метода Bundle.loadClass (...) пакета-получателя.)
Работает с java.util.List или другими сериализуемыми классами. Он также работает для пользовательских типов, которые содержат поля других пользовательских типов, если они не являются массивами.
Так что вопрос: есть ли разница в том, как массивы де / сериализуются? Или они загружены по-разному?