相信Apache的大名各位一定不会陌生,Java领域中常用的Ant,Maven,Struts1~2等都是托管在Apache下的项目,而在使用Apache框架的时候,通常要添加框架的依赖包,包括apache-commons系列的依赖包,相信读者对此也不会陌生,而apache-common是非常有用的工具包,包含了很多开源的工具,用于解决平时编程经常会遇到的问题,减少重复劳动
一个优秀的类应该重写toString,hashCode,equals,compareTo方法,我们来看一下apache如何带我们简化这些操作,以下示例支持两种形式,一种是通过逐个参数添加从而精细控制那些参数参与比较和输出,另一种是通过反射让全部参数都参与比较和输出
Builder系列
- //ToStringBuilder
- @Override
- public String toString() {
- return new ToStringBuilder(this).append(this.getId())
- .append(this.getUsername()).toString();
- }
- @Override
- public String toString() {
- return ToStringBuilder.reflectionToString(this);
- }
- // 以上输出格式为 Test@1270b73[<null>,<null>]
- // HashCodeBuilder
- @Override
- public int hashCode() {
- return HashCodeBuilder.reflectionHashCode(this);
- }
- @Override
- public int hashCode() {
- return new HashCodeBuilder(this).append(this.getId())
- .append(this.getUsername()).hashCode();
- }
- // EqulasBuilder
- @Override
- public boolean equals(Object obj) {
- if (this == obj) {
- return true;
- }
- if (obj.getClass() == Test.class) {
- Test test = (Test) obj;
- return new EqualsBuilder().append(this.getId(), test.getId())
- .append(this.getUsername(), test.getUsername()).isEquals();
- }
- return false;
- }
- @Override
- public boolean equals(Object obj) {
- return EqualsBuilder.reflectionEquals(this, obj);
- }
- // CompareToBuilder
- @Override
- public int compareTo(Test o) {
- return CompareToBuilder.reflectionCompare(this, o);
- }
- @Override
- public int compareTo(Test o) {
- return new CompareToBuilder().append(this.getId(), o.getId())
- .append(this.getUsername(), o.getUsername()).toComparison();
- }
- //ToStringBuilder
- @Override
- public String toString() {
- return new ToStringBuilder(this).append(this.getId())
- .append(this.getUsername()).toString();
- }
- @Override
- public String toString() {
- return ToStringBuilder.reflectionToString(this);
- }
- // 以上输出格式为 Test@1270b73[<null>,<null>]
- // HashCodeBuilder
- @Override
- public int hashCode() {
- return HashCodeBuilder.reflectionHashCode(this);
- }
- @Override
- public int hashCode() {
- return new HashCodeBuilder(this).append(this.getId())
- .append(this.getUsername()).hashCode();
- }
- // EqulasBuilder
- @Override
- public boolean equals(Object obj) {
- if (this == obj) {
- return true;
- }
- if (obj.getClass() == Test.class) {
- Test test = (Test) obj;
- return new EqualsBuilder().append(this.getId(), test.getId())
- .append(this.getUsername(), test.getUsername()).isEquals();
- }
- return false;
- }
- @Override
- public boolean equals(Object obj) {
- return EqualsBuilder.reflectionEquals(this, obj);
- }
- // CompareToBuilder
- @Override
- public int compareTo(Test o) {
- return CompareToBuilder.reflectionCompare(this, o);
- }
- @Override
- public int compareTo(Test o) {
- return new CompareToBuilder().append(this.getId(), o.getId())
- .append(this.getUsername(), o.getUsername()).toComparison();
- }
使用commons能最大程度的简化代码,实现one-line编程,注意使用反射形式的时候,static和transient不会参与比较或输出,要特别注意
有些情况下,Arrays满足不到你对数组的操作?不要紧,ArrayUtils帮你
ArrayUtils
- public class TestMain {
- public static void main(String[] args) {
- int[] nums1 = { 1, 2, 3, 4, 5, 6 };
- // 通过常量创建新数组
- int[] nums2 = ArrayUtils.EMPTY_INT_ARRAY;
- // 比较两个数组是否相等
- ArrayUtils.isEquals(nums1, nums2);
- // 输出数组,第二参数为数组为空时代替输出
- ArrayUtils.toString(nums1, "array is null");
- // 克隆新数组,注意此拷贝为深拷贝
- int[] nums3 = ArrayUtils.clone(nums1);
- // 截取数组
- ArrayUtils.subarray(nums1, 1, 2);
- // 判断两个数组长度是否相等
- ArrayUtils.isSameLength(nums1, nums2);
- // 判断两个数组类型是否相等,注意int和Integer比较时不相等
- ArrayUtils.isSameType(nums1, nums2);
- // 反转数组
- ArrayUtils.reverse(nums1);
- // 查找数组元素位置
- ArrayUtils.indexOf(nums1, 5);
- // 查找数组元素最后出现位置
- ArrayUtils.lastIndexOf(nums1, 4);
- // 查找元素是否存在数组中
- ArrayUtils.contains(nums1, 2);
- // 将基本数组类型转为包装类型
- Integer[] nums4 = ArrayUtils.toObject(nums1);
- // 判断是否为空,length=0或null都属于
- ArrayUtils.isEmpty(nums1);
- // 并集操作,合并数组
- ArrayUtils.addAll(nums1, nums2);
- // 增加元素,在下标5中插入10,注意此处返回是新数组
- ArrayUtils.add(nums1, 5, 1111);
- // 删除指定位置元素,注意返回新数组,删除元素后面的元素会前移,保持数组有序
- ArrayUtils.remove(nums1, 5);
- // 删除数组中值为10的元素,以值计算不以下标
- ArrayUtils.removeElement(nums1, 10);
- }
- }
- public class TestMain {
- public static void main(String[] args) {
- int[] nums1 = { 1, 2, 3, 4, 5, 6 };
- // 通过常量创建新数组
- int[] nums2 = ArrayUtils.EMPTY_INT_ARRAY;
- // 比较两个数组是否相等
- ArrayUtils.isEquals(nums1, nums2);
- // 输出数组,第二参数为数组为空时代替输出
- ArrayUtils.toString(nums1, "array is null");
- // 克隆新数组,注意此拷贝为深拷贝
- int[] nums3 = ArrayUtils.clone(nums1);
- // 截取数组
- ArrayUtils.subarray(nums1, 1, 2);
- // 判断两个数组长度是否相等
- ArrayUtils.isSameLength(nums1, nums2);
- // 判断两个数组类型是否相等,注意int和Integer比较时不相等
- ArrayUtils.isSameType(nums1, nums2);
- // 反转数组
- ArrayUtils.reverse(nums1);
- // 查找数组元素位置
- ArrayUtils.indexOf(nums1, 5);
- // 查找数组元素最后出现位置
- ArrayUtils.lastIndexOf(nums1, 4);
- // 查找元素是否存在数组中
- ArrayUtils.contains(nums1, 2);
- // 将基本数组类型转为包装类型
- Integer[] nums4 = ArrayUtils.toObject(nums1);
- // 判断是否为空,length=0或null都属于
- ArrayUtils.isEmpty(nums1);
- // 并集操作,合并数组
- ArrayUtils.addAll(nums1, nums2);
- // 增加元素,在下标5中插入10,注意此处返回是新数组
- ArrayUtils.add(nums1, 5, 1111);
- // 删除指定位置元素,注意返回新数组,删除元素后面的元素会前移,保持数组有序
- ArrayUtils.remove(nums1, 5);
- // 删除数组中值为10的元素,以值计算不以下标
- ArrayUtils.removeElement(nums1, 10);
- }
- }
还在使用传统反射吗?还在被反射的样板代码困扰?看commons如何帮助我们简化反射的工作,从样板代码抽身
ClassUtils
- public class TestMain {
- public static void main(String[] args) {
- // 获取Test类所有实现的接口
- ClassUtils.getAllInterfaces(Test.class);
- // 获取Test类所有父类
- ClassUtils.getAllSuperclasses(Test.class);
- // 获取Test类所在的包名
- ClassUtils.getPackageName(Test.class);
- // 获取Test类简单类名
- ClassUtils.getShortClassName(Test.class);
- // 判断是否可以转型
- ClassUtils.isAssignable(Test.class, Object.class);
- // 判断是否有内部类
- ClassUtils.isInnerClass(Test.class);
- }
- }
- public class TestMain {
- public static void main(String[] args) {
- // 获取Test类所有实现的接口
- ClassUtils.getAllInterfaces(Test.class);
- // 获取Test类所有父类
- ClassUtils.getAllSuperclasses(Test.class);
- // 获取Test类所在的包名
- ClassUtils.getPackageName(Test.class);
- // 获取Test类简单类名
- ClassUtils.getShortClassName(Test.class);
- // 判断是否可以转型
- ClassUtils.isAssignable(Test.class, Object.class);
- // 判断是否有内部类
- ClassUtils.isInnerClass(Test.class);
- }
- }
ConstructorUtils
- public class TestMain {
- public static void main(String[] args) {
- // 获取参数为String的构造函数
- ConstructorUtils.getAccessibleConstructor(Test.class, String.class);
- // 执行参数为String的构造函数
- Test test = (Test) ConstructorUtils.invokeConstructor(Test.class,
- "Hello");
- }
- }
- public class TestMain {
- public static void main(String[] args) {
- // 获取参数为String的构造函数
- ConstructorUtils.getAccessibleConstructor(Test.class, String.class);
- // 执行参数为String的构造函数
- Test test = (Test) ConstructorUtils.invokeConstructor(Test.class,
- "Hello");
- }
- }
MethodUtils
- public static void main(String[] args) throws NoSuchMethodException,
- IllegalAccessException, InvocationTargetException {
- // 调用无参方法
- Test test = new Test();
- MethodUtils.invokeMethod(test, "publicHello", null);
- // 调用一参方法
- MethodUtils.invokeMethod(test, "publicHello", "Hello");
- // 调用多参方法
- MethodUtils.invokeMethod(test, "publicHello", new Object[] { "100",
- new Integer(10) });
- // 调用静态方法
- MethodUtils.invokeStaticMethod(Test.class, "staticHello", null);
- }
- public static void main(String[] args) throws NoSuchMethodException,
- IllegalAccessException, InvocationTargetException {
- // 调用无参方法
- Test test = new Test();
- MethodUtils.invokeMethod(test, "publicHello", null);
- // 调用一参方法
- MethodUtils.invokeMethod(test, "publicHello", "Hello");
- // 调用多参方法
- MethodUtils.invokeMethod(test, "publicHello", new Object[] { "100",
- new Integer(10) });
- // 调用静态方法
- MethodUtils.invokeStaticMethod(Test.class, "staticHello", null);
- }
FieldUtils
- public class TestMain {
- public static void main(String[] args) throws IllegalAccessException {
- Test test = new Test("1", "Ray", "hello");
- // 以下两个方法完全一样,都能获取共有或私有变量,因为第三个参数都设置了不检查
- FieldUtils.getDeclaredField(Test.class, "username", true);
- FieldUtils.getField(Test.class, "username", true);
- // 读取私有或公共变量的值
- FieldUtils.readField(test, "username", true);
- // 读取静态变量
- FieldUtils.readStaticField(Test.class, "STATIC_FIELD");
- // 写入私有或共有变量
- FieldUtils.writeField(test, "username", "RayRay", true);
- // 写入静态变量
- FieldUtils.writeStaticField(Test.class, "STATIC_FIELD", "static_value");
- }
- }
- public class TestMain {
- public static void main(String[] args) throws IllegalAccessException {
- Test test = new Test("1", "Ray", "hello");
- // 以下两个方法完全一样,都能获取共有或私有变量,因为第三个参数都设置了不检查
- FieldUtils.getDeclaredField(Test.class, "username", true);
- FieldUtils.getField(Test.class, "username", true);
- // 读取私有或公共变量的值
- FieldUtils.readField(test, "username", true);
- // 读取静态变量
- FieldUtils.readStaticField(Test.class, "STATIC_FIELD");
- // 写入私有或共有变量
- FieldUtils.writeField(test, "username", "RayRay", true);
- // 写入静态变量
- FieldUtils.writeStaticField(Test.class, "STATIC_FIELD", "static_value");
- }
- }
读者在使用时可能会发现,MethodUtils和ConstructUtils在org.apache.commons.lang.reflect和org.apache.commons.beanutils都存在,但FieldUtils和ClassUtils只在reflect当中存在,因为beanutils提供了另外一种名为PropertyUtils的对属性存取更为方便的工具,但PropertyUtils不能获取传统反射的Field对象,笔者建议MethodUtils和ConstructUtils应该倾向使用beanutils,因为beanutils就是为反射而存在,更专业(虽然提供的方法几乎一样),而使用ClassUtils和要获取传统的Field对象时使用reflect中的FieldUtils
总结:
commons工具包很多开源组织都有提供,例如google,spring,apache都有各自的工具包,有众多的选择,但最终的目的只是为了方便我们程序的开发和维护,简化我们编写一些常用的逻辑,提升我们开发的效率,从而达到活在开源,善用开源
相关推荐
Apache Commons Lang是一个非常重要的Java库,它为Java标准类库提供了许多实用的工具类和扩展。这个资源包包含了丰富的功能,极大地增强了Java开发者的生产力。标题中的"org.apache.commons.lang包"指的是该库的主要...
Apache Commons Lang是Java开发中的一个非常重要的开源工具库,它提供了一系列实用的工具类,极大地丰富了Java的标准库,为开发者提供了更便捷、高效的方法来处理常见的编程任务。Lang包主要包含了对字符串操作、...
Apache Commons 是一个由 Apache 软件基金会维护的开源项目,它提供了许多Java语言的实用工具类库。在这个压缩包中,我们重点关注 Lang、IO 和 Collection 三个模块的源码及相关的单元测试(UT)。这些模块是Java...
2. **LICENSE.txt**: Apache Commons Lang遵循Apache软件许可证2.0版,这是一个非常宽松的开源许可证,允许自由使用、修改和分发代码,只要保留原有的版权信息即可。 3. **NOTICE.txt**: 这个文件通常包含项目中...
Apache Commons Lang包源代码是Java开发中的一个关键资源,它为Java程序员提供了许多实用的工具类,涵盖了字符串处理、日期时间、数学运算、反射等多个领域。这个开源项目由Apache Software Foundation维护,旨在...
2. **Lang**:Apache Commons Lang 是对Java标准库`java.lang`包的扩展和增强。它提供了许多实用工具类,包括异常处理、字符串操作、日期和时间格式化、枚举操作等,大大丰富了Java基础类的功能。 3. **Math**:...
1. **Apache Commons Lang**: 这个模块提供了一系列高级的Java语言功能,包括字符串操作(如格式化、比较、拼写检查)、数组操作、日期和时间处理、反射工具等。例如,StringUtils类提供了大量的静态方法,可以方便...
Apache Commons Lang是Java开发者们广泛使用的开源库之一,其中的2.6版本以其强大的功能和稳定性,在Web开发领域备受推崇。这个工具包提供了大量实用的类和方法,极大地扩展了Java语言的功能,使得开发者能够更加...
5. Apache Commons Lang: 这是Java语言功能的扩展,提供了字符串操作、日期时间处理、枚举工具、数学运算等类。例如,StringUtils提供了丰富的字符串操作方法,DateUtils提供了日期和时间的便捷处理。 6. Apache ...
Apache Commons 是一个由 Apache 软件基金会维护的开源项目,它提供了大量的 Java 类库,这些类库包含了许多实用的功能,极大地丰富了 Java 核心库的功能,为开发者提供了更强大的工具集。在Web开发中,Apache ...
首先,`commons-lang-2.6.jar` 是Apache Commons Lang项目的二进制库,包含了众多实用的工具类,如字符串处理、数组操作、日期时间处理等。这些工具类在日常开发中起到了至关重要的作用,比如 `StringUtils` 类提供...
1. **Apache Commons Lang**: 这个模块提供了许多高级字符串处理、日期和时间操作、数学计算以及类型转换等功能。例如,StringUtils 提供了各种字符串操作,如空白字符处理、字符串比较、格式化等;ClassUtils 可以...
Apache Commons 是一个由 Apache 软件基金会维护的开源项目集合,它提供了许多Java实用工具类,以增强Java标准库的功能。这些jar包是开发者在处理常见编程任务时的得力助手,涵盖范围广泛,包括数据结构、网络通信、...
Apache Commons Lang遵循Apache软件许可证2.0版,这意味着该库是开源的,可以自由使用、修改和分发,但需要保留原始的版权和许可声明。 总的来说,Apache Commons Lang 2.4在JCO与SAP的对接中扮演着重要角色,提供...
Apache Commons Lang是Apache软件基金会开发的一个开源项目,旨在为Java开发提供一组不包含在JDK中的通用工具类。 Lang项目的主要目标是提供一系列高质量的实用工具类,这些类涵盖了字符串处理、日期和时间操作、...
Apache Commons 是一个由 Apache 软件基金会维护的开源项目集合,它提供了大量的 Java 类库,这些类库弥补了 Java 核心库中的一些不足,为开发者提供了实用且高效的工具和组件。Apache Commons 项目旨在简化开发过程...
Apache Commons 是一个由 Apache 软件基金会维护的开源项目,它提供了许多Java库,用于解决常见的编程任务。这些库增强了Java标准库的功能,为开发者提供了便利和效率。在这个特定的压缩包中,包含了几个Apache ...
Apache Commons是Apache软件基金会提供的一个开源Java工具包,它包含了许多独立的Java库,涉及的领域包括字符串操作、数学运算、数组操作、对象反射、XML处理等。本知识点将围绕Apache Commons文档中的关键组件展开...
Apache Commons Lang是Apache软件基金会的一个开源项目,旨在帮助开发者解决日常编程任务。 描述中的"hashCodeBuilder EqualsBuilder ToStringBuilder"提到了三个关键的类,它们都是Apache Commons Lang中用于构建...
Apache Commons Lang 是一个由Apache软件基金会开发的Java库,它的核心部分是`commons-lang3-3.0.js`,这个JavaScript版本的工具集是为了在Web环境中提供与Java Commons Lang相似的功能。这个库包含了大量用于处理...