关于java的包Package中同名类的冲突及其理解

 更新时间:2023年07月10日 15:33:53   作者:钟眞龙  
这篇文章主要介绍了关于java的包Package中同名类的冲突及其理解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

java的包Package中同名类的冲突及理解

在一个项目中建立三个包分别为

  • chapter2
  • pack2
  • pack3

其中初始化(主)函数在InitialTelphone类里,看图显然是在chapter2包里。

这是chapter2包下的Telphone类实现

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类实现

package pack2;
public class Telphone {
     public Telphone() {
		// TODO Auto-generated constructor stub
    	 System.out.println("第二个包的类Telphone");
	}
}

这是pack3包下的Telphone类实现

package pack3;
public class Telphone {
   public Telphone() {
	// TODO Auto-generated constructor stub
	   System.out.println("第三个包的Telphone类");
}
}

chapter2包下的initialTelphone类实现

package chapter2;
public class InitalTelphone {
	public static void main(String[] args) {
		//通过无参方法生成对象
	 Telphone tel=new Telphone();	
	}
}

在initialTelphone文件写没有导入包pack2.Telphone和pack3.Telphone

执行程序将会得到以下结果:

第一个包的Telphone类

若在initialTelphone文件中导入pack2.telphone

intialTelphone代码改变如下:

package chapter2;
import pack2.Telphone;
public class InitalTelphone {
	public static void main(String[] args) {
		//通过无参方法生成对象
	 Telphone tel=new Telphone();
	}
}

执行程序会发现结果为:  

第二个包的类Telphone

但是如果导入的包形式为:impor pack2.*;

package chapter2;
import pack2.*;
public class InitalTelphone {
	public static void main(String[] args) {
		//通过无参方法生成对象
	 Telphone tel=new Telphone();
	}
}

程序运行结果又发生了变化:

第一个包的Telphone类

如果同时导入pack2.Telphone和pack3.Telphone

则会发生包冲突报错

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();
	 //有参构造方法生成对象
	 //Telphone tel2=new Telphone(4.0f,3.0f,1.5f);
	}
}

程序执行结果为:

第三个包的Telphone类

显然如果把pack3.Telphone格式也改为pack3.*,结果可想而知:

第一个包的Telphone类

但是如果把chapter2中的Telphone类给删除了

导入包的格式为pack2.*;pack3.*;

运行程序就会出现冲突错误:

        The type Telphone is ambiguousThe type Telphone is ambiguous

如果只导入Pack2.*或者只导入Pack3.*则又可以运行成功:

(import Pack2.*;)结果:第二个包的Telphone类

(import Pack3.*;)结果:第三个包的Telphone类

通过上述程序的测试,

我知道了包重名类的简单运行机制:

1、如果没有导入任何包,主函数运行时创建类的实例首先从自己所在的包里面找

2、如果导入一个包,并且导入该包的形式精确到重名的类,则主函数创建重名类实例将会从导入的包里找

3、如果导入一个包,包的格式为  import 包名.*;类型的,则主函数创建重名类实例时首先在主函数自己所在的包里找,找不到了再去导入的.*包里面找

4、如果导入多个包,并且导入的多个包中只有一个导入类型精确到重名类,则主函数创建重名类实例时在导入精确到类的包里面找。

5、如果导入多个包,并且读入的多个包中都是(import 包名.*;)类型的,主函数创建重名类实例时直接在自己所在包里找;如果找不到,并且导入的多个包里有两个同名类就会报错 ;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解读nacos获取配置文件的大致过程

    解读nacos获取配置文件的大致过程

    这篇文章主要介绍了nacos获取配置文件的大致过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Java语言实现简单FTP软件 FTP软件效果图预览之下载功能(2)

    Java语言实现简单FTP软件 FTP软件效果图预览之下载功能(2)

    这篇文章主要为大家详细介绍了Java语言实现简单FTP软件,FTP软件效果图预览之下载功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Mybatis如何从数据库中获取数据存为List类型(存为model)

    Mybatis如何从数据库中获取数据存为List类型(存为model)

    这篇文章主要介绍了Mybatis如何从数据库中获取数据存为List类型(存为model),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Windows系统下JDK1.8与JDK11版本切换超详细教程

    Windows系统下JDK1.8与JDK11版本切换超详细教程

    这篇文章主要给大家介绍了关于Windows系统下JDK1.8与JDK11版本切换的超详细教程,我们可以有多个工程项目,用的JDK版本不一样,这个时候就需要进行自由切换JDK版本了,需要的朋友可以参考下
    2023-07-07
  • Java SpringCache+Redis缓存数据详解

    Java SpringCache+Redis缓存数据详解

    本篇文章主要介绍了浅谈SpringCache与redis缓存数据的解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-10-10
  • Mybatis通过Spring完成代理类注入的流程分析

    Mybatis通过Spring完成代理类注入的流程分析

    这篇文章主要介绍了Mybatis通过Spring完成代理类注入的流程分析,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • @Async注解的使用以及注解失效问题的解决

    @Async注解的使用以及注解失效问题的解决

    在Spring框架中,@Async注解用于声明异步任务,可以修饰类或方法,使用@Async时,必须确保方法为public,且类为Spring管理的Bean,启用异步任务需要在主类上添加@EnableAsync注解,默认线程池为SimpleAsyncTaskExecutor
    2024-09-09
  • logback标记日志过滤器MarkerFilter源码解读

    logback标记日志过滤器MarkerFilter源码解读

    这篇文章主要为大家介绍了logback标记日志过滤器MarkerFilter源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Java数据结构中关于AVL树的实现方法详解

    Java数据结构中关于AVL树的实现方法详解

    这篇文章主要介绍了Java数据结构中关于AVL树的实现方法,AVL树是高度平衡的二叉树,它的特点是AVL树中任何节点的两个子树的高度最大差别为1,本文主要给大家介绍了Java语言如何实现AVL树,需要的朋友可以参考下
    2024-02-02
  • Java中File类中常用方法详解

    Java中File类中常用方法详解

    这篇文章主要为大家详细介绍了File类中常用方法的程序演示,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08

最新评论