關(guān)于java的包Package中同名類的沖突及其理解
java的包Package中同名類的沖突及理解
在一個項目中建立三個包分別為
chapter2pack2pack3

其中初始化(主)函數(shù)在InitialTelphone類里,看圖顯然是在chapter2包里。
這是chapter2包下的Telphone類實現(xiàn)
package chapter2;
public class Telphone {
//屬性
private float cup;
private float screen;
private float mem;
//get set方法
public float getScreen()
{
return screen;
}
public void setScreen(float newScreen)
{
screen=newScreen;
}
//方法
public Telphone()
{
System.out.println("第一個包的Telphone類");
}
}這是pack2包下的Telphone類實現(xiàn)
package pack2;
public class Telphone {
public Telphone() {
// TODO Auto-generated constructor stub
System.out.println("第二個包的類Telphone");
}
}這是pack3包下的Telphone類實現(xiàn)
package pack3;
public class Telphone {
public Telphone() {
// TODO Auto-generated constructor stub
System.out.println("第三個包的Telphone類");
}
}chapter2包下的initialTelphone類實現(xiàn)
package chapter2;
public class InitalTelphone {
public static void main(String[] args) {
//通過無參方法生成對象
Telphone tel=new Telphone();
}
}在initialTelphone文件寫沒有導(dǎo)入包pack2.Telphone和pack3.Telphone
執(zhí)行程序?qū)玫揭韵陆Y(jié)果:
第一個包的Telphone類
若在initialTelphone文件中導(dǎo)入pack2.telphone
intialTelphone代碼改變?nèi)缦拢?/p>
package chapter2;
import pack2.Telphone;
public class InitalTelphone {
public static void main(String[] args) {
//通過無參方法生成對象
Telphone tel=new Telphone();
}
}執(zhí)行程序會發(fā)現(xiàn)結(jié)果為:
第二個包的類Telphone
但是如果導(dǎo)入的包形式為:impor pack2.*;
package chapter2;
import pack2.*;
public class InitalTelphone {
public static void main(String[] args) {
//通過無參方法生成對象
Telphone tel=new Telphone();
}
}程序運(yùn)行結(jié)果又發(fā)生了變化:
第一個包的Telphone類
如果同時導(dǎo)入pack2.Telphone和pack3.Telphone
則會發(fā)生包沖突報錯
The import pack3.Telphone collides with another import statement
package chapter2;
import pack2.Telphone;
import pack3.Telphone;;
public class InitalTelphone {
public static void main(String[] args) {
//通過無參方法生成對象
Telphone tel=new Telphone();
}
}但是把pack2.telphone格式改為pack2.*,pack3.Telphone保持不變
package chapter2;
import pack2.*;
import pack3.Telphone;;
public class InitalTelphone {
public static void main(String[] args) {
//通過無參方法生成對象
Telphone tel=new Telphone();
//有參構(gòu)造方法生成對象
//Telphone tel2=new Telphone(4.0f,3.0f,1.5f);
}
}程序執(zhí)行結(jié)果為:
第三個包的Telphone類
顯然如果把pack3.Telphone格式也改為pack3.*,結(jié)果可想而知:
第一個包的Telphone類
但是如果把chapter2中的Telphone類給刪除了
導(dǎo)入包的格式為pack2.*;pack3.*;
運(yùn)行程序就會出現(xiàn)沖突錯誤:
The type Telphone is ambiguousThe type Telphone is ambiguous
如果只導(dǎo)入Pack2.*或者只導(dǎo)入Pack3.*則又可以運(yùn)行成功:
(import Pack2.*;)結(jié)果:第二個包的Telphone類
(import Pack3.*;)結(jié)果:第三個包的Telphone類
通過上述程序的測試,
我知道了包重名類的簡單運(yùn)行機(jī)制:
1、如果沒有導(dǎo)入任何包,主函數(shù)運(yùn)行時創(chuàng)建類的實例首先從自己所在的包里面找
2、如果導(dǎo)入一個包,并且導(dǎo)入該包的形式精確到重名的類,則主函數(shù)創(chuàng)建重名類實例將會從導(dǎo)入的包里找
3、如果導(dǎo)入一個包,包的格式為 import 包名.*;類型的,則主函數(shù)創(chuàng)建重名類實例時首先在主函數(shù)自己所在的包里找,找不到了再去導(dǎo)入的.*包里面找
4、如果導(dǎo)入多個包,并且導(dǎo)入的多個包中只有一個導(dǎo)入類型精確到重名類,則主函數(shù)創(chuàng)建重名類實例時在導(dǎo)入精確到類的包里面找。
5、如果導(dǎo)入多個包,并且讀入的多個包中都是(import 包名.*;)類型的,主函數(shù)創(chuàng)建重名類實例時直接在自己所在包里找;如果找不到,并且導(dǎo)入的多個包里有兩個同名類就會報錯 ;
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
一篇超詳細(xì)的Spring Boot對jdbc支持的文章
JdbcTemplate 是在JDBC API基礎(chǔ)上提供了更抽象的封裝,并提供了基于方法注解的事務(wù)管理能力。 通過使用SpringBoot自動配置功能并代替我們自動配置beans,下面給大家介紹spring boot中使用JdbcTemplate相關(guān)知識,一起看看吧2021-07-07
使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題
這篇文章主要介紹了使用IDEA異常斷點來定位java.lang.ArrayStoreException的問題,平常開發(fā)過程中面對這種描述不夠清楚,無法定位具體原因的問題該如何處理,下面我們來一起學(xué)習(xí)一下吧2019-06-06
使用Java visualVM監(jiān)控遠(yuǎn)程JVM的流程分析
我們經(jīng)常需要對我們的開發(fā)的軟件做各種測試, 軟件對系統(tǒng)資源的使用情況更是不可少,JDK1.6開始自帶的VisualVM就是不錯的監(jiān)控工具,本文給大家分享使用Java visualVM監(jiān)控遠(yuǎn)程JVM的問題,感興趣的朋友跟隨小編一起看看吧2021-05-05
SpringBoot+mybatis+thymeleaf實現(xiàn)登錄功能示例
這篇文章主要介紹了SpringBoot+mybatis+thymeleaf實現(xiàn)登錄功能示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07

