Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Важен ли порядок загрузки jar-ов? 
:(
    Опции темы
Dims
Дата 16.2.2009, 16:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1016
Регистрация: 21.11.2006

Репутация: 4
Всего: 11



У меня есть библиотека, в которой происходит загрузка ресурса вот при помощи такого кода в статической функции:

Код

ObjectInputStream in =
            new ObjectInputStream(new BufferedInputStream(input));
        Object obj = in.readObject();
        in.close();


Во время выполнения строки in.readObject ИНОГДА (в зависимости от того, в какой программе я использую библиотеку), возникает исключительная ситуация 

java.lang.ClassNotFoundException

При этом, тот класс, который она не может найти, вроде бы, присутствует в наборе используемых библиотек.

Такое впечатление, что в тот момент, когда выполняется указанная строка, джар с нужным классом просто ещё не подгрузился.

Может ли такое быть? Или она просто обязана искать класс в тот момент, когда это требуется?

PM MAIL   Вверх
ivg
Дата 16.2.2009, 19:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Autonomous R&D
**


Профиль
Группа: Участник
Сообщений: 686
Регистрация: 8.2.2006
Где: Екатеринбург

Репутация: 33
Всего: 81



Смотрите javadoc для метода ObjectInputStream.html#resolveClass(java.io.ObjectStreamClass)
Цитата

The default implementation of this method in ObjectInputStream returns the result of calling

     Class.forName(desc.getName(), false, loader)
 
where loader is determined as follows: if there is a method on the current thread's stack whose declaring class was defined by a user-defined class loader (and was not a generated to implement reflective invocations), then loader is class loader corresponding to the closest such method to the currently executing frame; otherwise, loader is null.
 Т. е. происходит попытка загрузить
Цитата(Dims @  16.2.2009,  18:50 Найти цитируемый пост)
тот класс, который она не может найти
 ClassLoader'ом, которым был загружен класс, из метода которого, был вызван in.readObject();, т. е. в данном случае класс вашей библиотеки. Если класс сериализованного объекта находится в другом месте, таким образом, что класс-лоадер библиотеки не может его загрузить, то, конечно, такое исключение вылетает.
1. Можно держать классы библиотеки и сериализуемых объектов в одном месте (неудобно).
2. Расширить класс java.io.ObjectInputStream и переопределить метод(ы) загрузки классов, чтобы можно было использовать определённый класс-лоадер. В качестве примера класс org.springframework.core.ConfigurableObjectInputStream

Это сообщение отредактировал(а) ivg - 16.2.2009, 19:20
PM MAIL   Вверх
Dims
Дата 16.2.2009, 20:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1016
Регистрация: 21.11.2006

Репутация: 4
Всего: 11



А как-то можно определить лоадер, который не может сработать, чтобы объективно сравнить работу в версии, когда библиотека работает и когда нет?
PM MAIL   Вверх
ivg
Дата 16.2.2009, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Autonomous R&D
**


Профиль
Группа: Участник
Сообщений: 686
Регистрация: 8.2.2006
Где: Екатеринбург

Репутация: 33
Всего: 81



Цитата(Dims @  16.2.2009,  22:10 Найти цитируемый пост)
А как-то можно определить лоадер, который не может сработать,

В классе вашей библиотеки
Код

ThisLibraryClass.class.getClassLoader();

PM MAIL   Вверх
Dims
Дата 25.2.2009, 20:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1016
Регистрация: 21.11.2006

Репутация: 4
Всего: 11



Цитата(ivg @  16.2.2009,  19:18 Найти цитируемый пост)
1. Можно держать классы библиотеки и сериализуемых объектов в одном месте (неудобно).

А что означает "в одном месте"?
PM MAIL   Вверх
Dims
Дата 25.2.2009, 22:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1016
Регистрация: 21.11.2006

Репутация: 4
Всего: 11



Вот я трассирую происходящее. Иду по вызовам функций. Везде один и тот же класслоадер. И вдруг -- бац -- в каком-то классе совершенно другой. 

Конкретно у меня везде WebappClassLoader, а в нужном месте вдруг StandardClassLoader.

Почему?


PM MAIL   Вверх
LSD
Дата 25.2.2009, 22:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 210
Всего: 538



Скорее всего потому, что используется класс из библиотек веб контейнера, а не из веб приложения.

Что за класс?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0879 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.