百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

package-info.java 的使用

wptr33 2025-08-02 22:16 2 浏览

package-info.java 介绍

pacakge-info.java 是一个 Java 文件目标是提供一个包级的文档说明及包级的注释。在 Java 5 之前,包级的文档是 package.html,是通过 JavaDoc 生成的。而在 Java 5 之后版本,包的描述以及相关的文档都可以写入 pacakge-info.java 文件

创建 package-info.java

pacakge-info.java 不能随便被创建,会报 This is not a valid Java qualified name 错误,类名无效,因为类名不能包括 -,那么怎么创建这个文件呢

创建一个普通的文件,文件名设置为 package-info.java 即可,或者从其它项目中复制一个

pacakge-info.java 只需要声明 package

package com.test;

package-info.java 用途

提供包级别的注释

package-info.java 添加注释

/**
 * 测试 package-info 的包注释功能
 * 
 * @author mimi
 * @since 1.0.0-RELEASE
 * @version 2.0.0-RELEASE
 */
package com.test;

执行 javadoc 之后查看效果图

  • 如何在 idea 中执行 javadoc

Tools -> Generate JavaDoc,选择 Output directory,在 Othre Command line arguments 中填入 -encoding utf-8 -charset UTF-8,用于解决中文乱码问题

提供包级别的注解

自定义一个注解

@Target(ElementType.PACKAGE)
@Retention(RetentionPolicy.RUNTIME)
public @interface PackageAnnotation {
}

在 package-info.java 上添加注解,注解加在 package 之上,注解的地方与平常用的注解稍有不同

@PackageAnnotation
package com.test;

获取包注解

public class Test {
    public static void main(String[] args) {
        System.out.println("Package Annotation:");
        Arrays.stream(Test.class.getPackage().getAnnotations())
                .forEach(System.out::println);
        System.out.println();
        System.out.println("Class Annotation:");
        Arrays.stream(Test.class.getAnnotations())
                .forEach(System.out::println);
    }
}

输入结果如下,通过包可以获取到包的注解。

Package Annotation:
@com.test.PackageAnnotation()

Class Annotation:


@Deprecated 的使用

@Deprecated 可以作用在一个类,一个方法或者一个变量上,意味着被标记的元素是过时的,在之后的版本可能不再支持,不建议使用。但如果是一整个功能下线,@Deprecated 也可以作用在包上,将整个包标记为过时。

@Deprecated
package com.test;

提供包级别的变量

package-info.java 中只能声明 default 默认访问权限的类,只能包内访问,其它包包括子包都不可访问。

package com.test;
class Constant {
    static final String PACKAGE_NAME = "Test";
}

同一个包下使用

public class Application {
    public static void main(String[] args) {
        System.out.println(Constant.PACKAGE_NAME);
    }
}

相关推荐

PQ03-分组求和

目标已知:销售清单求:每个销售员的销量合计方法数据准备...

好荐:一款数据库元数据管理平台工具

“元数据”的定义在不同的软件、项目、工程的定义范围都不太一样。本文这里指的是软件项目开发使用的数据库表结构信息。我今天介绍的这个开源项目叫Databasir,它是一个面向团队的关系型数据库模型文档管理...

MySQL 8.0 SQL优化黑科技,面试官都不一定知道!

前言提到SQL优化,大多数人想到的还是那些经典套路:建索引、避免全表扫描、优化JOIN顺序…这些确实是基础,但如果你还停留在MySQL5.7时代的优化思维,那就out了。MySQL8.0已经发布好...

MySQL数据库深度优化指南:从基础到架构层面的20个关键策略

一、核心性能优化原则数据最小化原则...

动物源性食品中兽药残留的检测——喹啉类药物残留

喹啉类药物(quinoxaline)是具有喹啉-N1,N4-二氧化物基本结构的一类化学合成的动物专用药,具有广谱抗菌、提高饲料转化率和促生长作用。1965年德国拜耳公司以邻硝基苯胺为原料合成喹乙醇(o...

适合普通开发者和产品经理的PHP应用模板开发AI的SaaS应用框架

简单到傻!Liang_SaaS适合普通开发者和产品经理的PHP应用模板开发AI的SaaS应用框架,利用Php开发AI的SaaS应用框架,是一个强大的内容管理仪表板模板,基于Bootstrap和...

Power Query 交错合并表格的方法

两张表格合并成一张表格,需要交错排列,表1取一行,表2取一行,这样排列在一起:前提是两张表的行数相同,内容排列顺序相同:我们来看两张表:表1:12列10行表2:11列10行行数相同列数不同,我们在数据...

ALTER使用方法

ALTER是SQL语言的一个关键字,用于修改已经存在的表的结构或属性,例如修改表的列、添加新列、删除列、重命名表等。下面是ALTER语句的常见用法:...

从 Excel 单元格的文字中拆分出数字,如何删除列之间多余的跳空?

很多同学会觉得Excel单个案例讲解有些碎片化,初学者未必能完全理解和掌握。不少同学都希望有一套完整的图文教学,从最基础的概念开始,一步步由简入繁、从入门到精通,系统化地讲解Excel的各个知...

Record.ToTable 求多列之间的差异

本期案例是对相同性质的列(字段名中字母一样的为同性质列)进行比较,如果行内对应的两列数据不一样,则在差异列中显示对应的列名名称,否则不显示。前后转换效果如下:解题套路1.Record.ToTable...

mysql给表增加字段

#挑战30天在头条写日记#...

MySQL中JSON的存储原理

前言:表中有json字段后,非索引查询性能变得非常糟糕起因是我有一张表,里面有json字段后,而当mysql表中有200w数据的时候,走非索引查询性能变得非常糟糕需要3到5s。因此对mysql的jso...

你会用PowerQuery统计字符串中各类字符出现的次数吗?

很多时候我们需要统计单个字符或某种字符出现的次数,那么在PowerQuery中怎么实现呢?01统计字符串中单一字符出现的次数有小伙伴提了一个问题:“PowerQuery是否有直接统计字符串中指定字符个...

亲身经历,对Gemini cli佩服的五体投地,太强了

GeminicliTipsforgettingstarted:1.Askquestions,editfiles,orruncommands....

MySQL实战:Json字段类型详解

"当产品经理第7次修改需求文档时,我的MySQL表结构终于崩溃了..."这样的场景你是否似曾相识?在快速迭代的互联网时代,固定表结构常常成为开发者的噩梦。但鲜为人知的是,你手中的My...