JAVA - package与import解析(一)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 一、为什么要引入package和import?这个问题和c++中引入命名空间是一样的,也是为了解决重名问题。java通过包机制来解决重名问题,也就相当于给重名的代码加一系列前缀,从而达到唯一标识的作用。


一、为什么要引入package和import?
这个问题和c++中引入命名空间是一样的,也是为了解决重名问题。java通过包机制来解决重名问题,也就相当于给重名的代码加一系列前缀,从而达到唯一标识的作用。

二、如何解决重名问题?
这个就有点像外国人的名字:如果我叫Jeason,我爸叫Kevin,我爷爷叫Bob,我爷爷的爸爸叫Peter。
那么如果没有人和我同名(Jeason),那么Jeason这个名字就能够唯一标识我了;而如果还有一个人也叫Jeason,那么我就加上我爸爸的名字Kevin,我就
是Kevin Jeason;如果那个人他爸爸也叫Kevin,那么我再加上我爷爷的名字,我就叫Bob Devin Jeason;如果他爸爸和爷爷的名字又和我爸爸和爷爷的
名字相同,那么我再加上我爷爷的爸爸的名字,我就叫Peter Bob Kevin Jeason ...
这样一来就解决了重名问题。
三、具体用法
在桌面上建立了一个Cat.java,内容为:

public class Cat
{
    public static void main(String[] args)
    {
        System.out.println("This is a Cat!");
    }
}

当然这样是可以正确编译运行的。
现在我再在前面加一个package,将这段代码打包一下:

package com.crazyacking.github;
public class Cat
{
    public static void main(String[] args)
    {
        System.out.println("This is a Cat!");
    }
}

编译通过,但是在执行程序时提示“错误:找不到或无法加载主类 Cat”。
为什么会出现这个问题呢?因为我们已经将Cat类打包,系统自然无法找到Cat类。

那现在我再在桌面上创建一个Dog.java,内容为:

public class Dog
{
     public static void main(String[] args)
     {
         Cat c=new Cat();
         System.out.println("This is a Dog!");
     }
}
    

在编译时会显示:无法找到Cat类,还是同样的问题;我们已经将Cat.java类打包了。
那么我们如何才能访问到Cat.java类呢?
其实,在java语言中,package是和文件的目录相对应的,我们在写程序的时候要随时将代码与文件联系在一起。
我们在封装类的时候,一般有这样一个默认的准则,即仿照域名的格式,将域名倒过来打包类。
既然我们打包了类,而package又是和文件对应,那么我们就建立文件夹把它放进去就行,将.class文件放在.com/crazyacking/github/文件夹下即可。


代码变为:

public class Dog
{
     public static void main(String[] args)
     {
         com.crazyacking.github.Cat c=new com.crazyacking.github.Cat(); 
         System.out.println("This is a Dog!");
     }
}

这样就能访问到Cat类了。但是,每次访问Cat类的时候前面都要写这么一大堆东西,不仅写着麻烦,看着也烦,这时候import就派上用场了。

 

import com.crazyacking.github.Cat;

public class Dog
{
     public static void main(String[] args)
     {
         Cat c=new Cat(); 
         System.out.println("This is a Dog!");
     }
}

然也可以将com.crazyacking.github中的全部子类都包含进来:

import com.crazyacking.github.*;

public class Dog
{
     public static void main(String[] args)
     {
         Cat c=new Cat(); 
         System.out.println("This is a Dog!");
     }
}

注意:“.*”只可以包含该文件夹下的类,但并不包括该文件下的子文件夹下的类。
通过package和import就可以完美的解决重名问题了。

四、相关拓展

如果我们包的路径太过于复杂而且该包被经常调用,我们还可以直接将包所在的文件夹路径直接加到环境变量的ClassPath下面。

这样一来,系统会首先根据ClassPath进行资源查找,避免了每次调用都要包含的问题。

另:在使用import来包含类时,包含的源代码可能对运行产生影响,可以将源代码移除,只留.class文件就行。

 

目录
相关文章
|
4天前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####
|
4天前
|
存储 分布式计算 Java
存算分离与计算向数据移动:深度解析与Java实现
【11月更文挑战第10天】随着大数据时代的到来,数据量的激增给传统的数据处理架构带来了巨大的挑战。传统的“存算一体”架构,即计算资源与存储资源紧密耦合,在处理海量数据时逐渐显露出其局限性。为了应对这些挑战,存算分离(Disaggregated Storage and Compute Architecture)和计算向数据移动(Compute Moves to Data)两种架构应运而生,成为大数据处理领域的热门技术。
17 2
|
4天前
|
设计模式 安全 Java
Java编程中的单例模式深入解析
【10月更文挑战第31天】在编程世界中,设计模式就像是建筑中的蓝图,它们定义了解决常见问题的最佳实践。本文将通过浅显易懂的语言带你深入了解Java中广泛应用的单例模式,并展示如何实现它。
|
3天前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
6 0
|
28天前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
63 0
|
28天前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
49 0
|
28天前
|
存储 Java C++
Collection-PriorityQueue源码解析
Collection-PriorityQueue源码解析
58 0
|
28天前
|
安全 Java 程序员
Collection-Stack&Queue源码解析
Collection-Stack&Queue源码解析
74 0
|
9天前
|
消息中间件 缓存 安全
Future与FutureTask源码解析,接口阻塞问题及解决方案
【11月更文挑战第5天】在Java开发中,多线程编程是提高系统并发性能和资源利用率的重要手段。然而,多线程编程也带来了诸如线程安全、死锁、接口阻塞等一系列复杂问题。本文将深度剖析多线程优化技巧、Future与FutureTask的源码、接口阻塞问题及解决方案,并通过具体业务场景和Java代码示例进行实战演示。
28 3
|
26天前
|
存储
让星星⭐月亮告诉你,HashMap的put方法源码解析及其中两种会触发扩容的场景(足够详尽,有问题欢迎指正~)
`HashMap`的`put`方法通过调用`putVal`实现,主要涉及两个场景下的扩容操作:1. 初始化时,链表数组的初始容量设为16,阈值设为12;2. 当存储的元素个数超过阈值时,链表数组的容量和阈值均翻倍。`putVal`方法处理键值对的插入,包括链表和红黑树的转换,确保高效的数据存取。
50 5

推荐镜像

更多