Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Java: Общие вопросы > Импорт пакета. Нужен ли исходник?


Автор: Tamerlann 14.2.2005, 14:55
Господа, помогите, пожалуста, разобраться:

В переменной classpath содержится c:\Java\lib
В этой дирректории я храню свои пакеты.

Я создаю файл, предположим такой: c:\Java\lib\P.java
в котором содержится класс P в пакете mypack.
Компилирую этот файл. Получаю дирректорию c:\Java\lib\mypack
и файл c:\Java\lib\mypack\P.class

Теперь, при попытке использовать данный пакет:

Код

1. import mypack.*;
2. ...
3. P p = new P();


компилятор ругается именно на строку №3 и говорит:

cannot access P
bad class file: C:\Java\lib\P.java
file does not contain class P
Please remove or make sure it appears in the correct subdirectory of the classpath.

Если импортировать так:
Код

import mypack.P;

то уже не ругается.

Если удалить сам исходник (я его переименовывал), т.е. P.java, например, в !P.java,
то тоже перестает ругаться.

И еще наблюдение: если класс в пакете объявить final:
Код

public final P {

то вообще не ругается, независимо от наличия исходника или способа импорта.

Вообще мне это все не мешает. Я обычно просто всегда перименовываю исходник после его окончательной компиляции. Но просто мне очнь интересно, что же на самом деле происходит? Как понять такое поведение?

Автор: Domestic Cat 14.2.2005, 19:00
Цитата
cannot access P
bad class file: C:\Java\lib\P.java
file does not contain class P


Потому что он содержит класс mypack.P а не Р.

Компилятор делает вот что:
1. Ищет в своих библиотеках, и не находит Р.
2. Ищет в папке jre<...>/lib/ext
3. Ищет в путях прописанных в CLASSPATH, если он пустой - ищет в текущей папке.
3. Т.к. ты используешь класс Р, а твой класс не принадлежит к-л пакету, то он считается принадлежащим дефаулт пакету, как и все файлы в текущей папке. Потому он и ищет в текущей директории, находит файл Р.java, пытается его откомпилить. Но он должен был бы находиться в папке mypack, вот компилятор и ругается. Если Р переименовать или удалить, компилятор смотрит на импорт и начинает искать пакет mypack в текущей директории, находит его, и все ок.
Можно было бы задать CLASSPATH=.:/mypathtodirectory/mypack/ - тогда все бы сработало и при непереименованном / неудаленном P.java.

Hасчет final ты чегo-тo перепутал, нe может быть таkого.

Автор: Tamerlann 17.2.2005, 13:59
Спасибо, кажется разобрался.
smile Правда, у меня возникло ещё больше вопросов, после этого ответа, но с ними оказалось просто разобраться. Вообще, оказывается очень удобно, хотя и немного запутанно сначала: можно регулировать будет он компилить импортируемый класс заново или нет, куда положит и т.д.

Вообщем, спасибо.

P.S. С final я правда перепутал, видимо я тогда импортировал конкретный пакет.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)