package-info.java

参考文章: http://blog.sina.com.cn/s/blog_93dc666c0101gzlr.html

对于package-info.java我们并不陌生,但又陌生。

在我们每次建立package包的时候会自动生成一个package-info.java文件。但这个文件内部并没有任何东西。

因-为特殊字符在java中不能作为文件名,因此我们不能在java中new Class的形式建立。

一种是建立一个package生成package-info.java,另一种是用文本编辑器建立一个文件复制进来。

package-info.java 属于特殊java文件,不同于以往的java文件。没有继承没有public、private修饰符

package-info.java作用:

  • 为标注在包上Annotation提供便利;
  • 声明友好类和包常量;
  • 提供包的整体注释说明。

以下是例子:

 其中 PackAnnotation注明作用到Package上:

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

 

package-info.java

/**
 * 本包主要做测试用,用于学习package-info.java文件的作用.
 * @author DennyZhao
 *
 */
@PackAnnotation
package pack.info.test;

import java.lang.annotation.Annotation;

/**
 * 本包单用Utils
 * @author DennyZhao
 *
 */
class CommonPackUtils{
    public static void formatPackage(String packName) {
        Package pack = Package.getPackage(packName);
        Annotation[] annotations = pack.getAnnotations();
        for(Annotation anno : annotations) {
            System.out.println(anno.annotationType().getName());
        }
    }
}
/**
 * 本包单用约束
 * @author DennyZhao
 *
 */
class CommonPackConstants{
    public static final String PACK_NAME = "pack.info.test";
}

 

 PackTest.java

public class PackTest {
    public static void main(String[] args) {
        CommonPackUtils.formatPackage(CommonPackConstants.PACK_NAME);
    }
}

 

从以上例子可以看出:

1. 我们的公共类CommonPackUtils只能在本package中使用,子包和兄弟包都不能使用。

2. 注解的作用范围控制在包上,则除此之外无法调用。

3. pack-info添加注释,会作为package的javadoc而存在。

 

转载于:https://www.cnblogs.com/DennyZhao/p/9549665.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值