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);
}
}
- 上一篇:C#入门 - 创建项目
- 下一篇:嘿,用Java实现文生图,就这么简单!
相关推荐
- 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...
- 一周热门
-
-
因果推断Matching方式实现代码 因果推断模型
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
git pull命令使用实例 git pull--rebase
-
git 执行pull错误如何撤销 git pull fail
-
面试官:git pull是哪两个指令的组合?
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)