Apache Commons项目简介之Attributes

2024-02-17 01:38

本文主要是介绍Apache Commons项目简介之Attributes,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                        Apache Commons项目简介之Attributes
0.简介
Apache Commons项目是专注于开发可重用的Java组件。
Apache Commons项目由三部分组成:
Commons Proper - 可重用Java组件库。
Commons Sandbox - Java组件开发工作空间。
Commons Dormant - sandbox中不活跃的项目存储库。
Apache Commons开发人员使每个组件尽可能少的依赖其他的lib,以便这些组件可以方便的部署,而不是需要将依赖的库依次部署。另外,Commons组件的接口尽可能的保持不变,这样可以在实现这些组件的时候针对接口进行开发,确保兼容性。
本文主要介绍第一部分的项目,即可重用的稳定的Java组件库。由于库中的每个子项目都包含了特定的功能,所以本文不会对这些功能面面俱到的介绍,而是针对库中的每个子项目,尽可能的介绍其应用场景,以及列举典型的样例。

1.Attributes介绍
Attribute是可以添加到类,方法以及成员的有值对象。该对象是只读的,常量,可以被其他具有相同值的对象进行无缝替代。例如,java.lang.Integer就是值对象,可以使用任何其他的同类的其他实例来替换当前的实例,前提是它们是equal的。而java.io.Socket就不是值对象,因为不能将一个socket实例使用其他的实例替换,因为它反应一个真实的资源,即链接。
因此,attribute类是可变的。并且不能使用Socket或者类似的类作为属性。

为类添加属性的一般方式如下,其中方括号内的为可选的:
@@[target] ClassName([constructor args] [named args])
target:attribute将被应用到那些子元素上面。类和成员没有子元素,但是方法有。方法的子元素可以是参数或者返回值。如果是参数,那么就使用.argument名字,例如:
/**
 * @@.arg1 MyAttribute()
 */
public Object myMethod (int arg1) { ... }
这样就可以将MyAttribute附加到方法的第一个参数上,而不是方法本身,这个属性通过Attributes.getParameterAttributes(Method, int)。
而为返回值添加属性是使用.return:
/**
 * @@.return MyAttribute()
 */
public Object myMethod (int arg1) { ... }
该属性可以通过Attributes.getReturnAttributes(Method)来获取。
ClassName:表示属性类的名字。可以使用full qualified name或者unqualified name。
constructor args:传递给构造方法的参数。
name args:通过使用set方法来为属性设置值。

所有属性的值的获取都是通过org.apache.commons.attributes.Attributes方法来获取的,详细api请参考JavaDoc。

attribute类必须包含了一个public的构造方法。

2.Attributes Demo程序
Attributes子项目可以供java开发人员来使用C#/.Net风格的属性。
a.Ant样例:
前提条件:下载以下jar文件并将其放在ANT安装目录的lib中。
关于Ant的更多信息,请参考:http://ant.apache.org/
    *api: commons-attributes-api-2.2.jar
    http://www.ibiblio.org/maven/commons-attributes/jars/commons-attributes-api-2.2.jar
    注意不要修改这个文件的名字,因为在build.xml文件中使用了该名字。
    *Ant task: commons-attributes-compiler-2.2.jar
    http://www.ibiblio.org/maven/commons-attributes/jars/commons-attributes-compiler-2.2.jar
    注意不要修改上面的两个文件的名字,因为在build.xml文件中使用了该名字。
    *qDox 1.5: qdox-1.5.jar
    http://www.ibiblio.org/maven/qdox/jars/qdox-1.5.jar

样例java代码如下:
import org.apache.commons.attributes.Attributes;

class MyAttribute {
    private final String ctorArg;
    private String namedArg = null;
   
    public MyAttribute (String ctorArg) {
        this.ctorArg = ctorArg;
    }
   
    public void setNamedArgument (String namedArg) {
        this.namedArg = namedArg;
    }
   
    public String toString () {
        return "[MyAttribute  constructor argument: /"" +
            ctorArg + "/" named argument: /"" + namedArg + "/"]";
    }
}
上面的类MyAttribute只是一个简单的java类,定义了一个常量和一个成员变量以及用于初始化常量的构造方法。
/**
 * @@MyAttribute ("This string is passed to the constructor.",
 *                namedArgument="This argument will be passed to the setNamedArgument method")
 */
public class AttributeDemo {
    public static void main (String args[]) {
        System.out.println (Attributes.getAttributes (AttributeDemo.class));
    }
}
通过使用Commons Attributes,我们给AttributeDemo类添加了一个实例,两个@表示这是一个属性,这使得Attribute编译器获取这个属性,第一个字符串传递给构造方法,第二个参数的格式为name = expression,结果是setNamedArgument被调用。
在main方法中,Attributes.getAttributes方法会返回附加给AttributeDemo类的所有属性集合。
build.xml文件只是包含了clean,compile-attributes,compile,run以及javadoc这些target。其中attibute-compiler的作用是生成额外的java source类(每个使用attributes的类都会生成一个额外的java类)。接下来这些额外的java source回合初始的java source一起被编译:
+------------+                              +--------------------+
|Java Sources|----> Attribute Compiler ---->|Generated Java Files|  
+------------+                              +--------------------+
      |                                                 |
      |                                                 |
      |               +-------------+                   |
      +-------------->|Java Compiler|<------------------+
                      +-------------+
                             |
                             v
                    +-----------------+
                    |Java .class files|
                    +-----------------+
!当然,在使用之前需要通过taskdef来启用Attribute Compiler。
<project default="run" name="commons-attributes ant demo" basedir=".">
    <taskdef resource="org/apache/commons/attributes/anttasks.properties"/>
接下来,就是使用Attribute编译器对java source进行编译:
<target name="compile-attributes" description="o Run the commons-attributes precompiler">
    <attribute-compiler destdir=".">
        <fileset dir="." includes="*.java"/>
    </attribute-compiler>
</target>
该步骤的结果就是生成包含attributes信息的java source文件。为既存的.java文件自动生成attribute repositories(.java文件),一旦生成成功之后,就可以进行正常的编译了。

在上面的例子中,使用了QDox项目的jar作为依赖。QDox是一个高速,低耗的javadoc解析器,用于从源代码中获取类/接口/方法的javadoc注释(即带@标记的注释)。主要用于代码生成器或者文档工具。笔者会在稍后的一篇文章中进行详细的介绍。

b.Maven样例
所有的文件都包含在maven_demo.zip(http://commons.apache.org/attributes/maven_demo.zip)中。
为了运行该程序,需要完成以下工作:
声明依赖-->安装commons-attributes插件-->通过设置project属性来启用插件。
声明依赖关系:
<dependency>
    <groupId>commons-attributes</groupId>
    <artifactId>commons-attributes-api</artifactId>
    <version>2.2</version>
</dependency>

<dependency>
    <groupId>commons-attributes</groupId>
    <artifactId>commons-attributes-compiler</artifactId>
    <version>2.2</version>
</dependency>
安装插件:
可以通过运行maven命令:
$ maven install
$ maven install-plugin
或者下载插件到maven的plugin目录来安装插件。
设置properties属性:
由于Maven会将所有的插件应用到所有被编译的projects,所以有必要显式的启用attribute compiler,以免不需要该插件的project错误的使用。
######################################################################
# Commons-Attributes
######################################################################
org.apache.commons.attributes.enable=true
org.apache.commons.attributes.index.enable=true

可以通过以下的命令运行程序:
$ unzip maven_demo.zip
$ cd maven_demo
$ maven run

3.依赖项目
ant1.5
maven-xdoc-plugin1.9.2(Site Only - v1.9.2)
qdox1.5
xerces2.2.1
xml-apis1.0.b2

4.后记
实际上,Attributes的功能与Tiger(Java5.0)中的annotations是一致的,可能5.0中的annotations的功能更强大一些。但是对于使用Java低版本sdk的用户来说,Commons-Attributes还是一个选择。
Apache开发人员的建议是,如果可以升级到5.0,那么尽量升级到5.0,而不是使用Attributes。一旦5.0的普及程度达到1.3和1.4的时候,关于metadata的其他开发都会停止,例如JSR175,MetaClass,qDox,JAM等。但是相对于这几种metadata框架,Attributes具有简单易用的API,强大的annotation特点,类型安全以及低消耗等特点。

5.小结
本文简要的介绍了apache commons项目的子项目Attributes项目的使用。

这篇关于Apache Commons项目简介之Attributes的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/716303

相关文章

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Apache Ignite缓存基本操作实例详解

《ApacheIgnite缓存基本操作实例详解》文章介绍了ApacheIgnite中IgniteCache的基本操作,涵盖缓存获取、动态创建、销毁、原子及条件更新、异步执行,强调线程池注意事项,避免... 目录一、获取缓存实例(Getting an Instance of a Cache)示例代码:二、动态

在IntelliJ IDEA中高效运行与调试Spring Boot项目的实战步骤

《在IntelliJIDEA中高效运行与调试SpringBoot项目的实战步骤》本章详解SpringBoot项目导入IntelliJIDEA的流程,教授运行与调试技巧,包括断点设置与变量查看,奠定... 目录引言:为良驹配上好鞍一、为何选择IntelliJ IDEA?二、实战:导入并运行你的第一个项目步骤1

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再