Java编程Commons lang组件简介

跟java.lang这个包的作用类似,Commons Lang这一组API也是提供一些基础的、通用的操作和处理,如自动生成toString()的结果、自动实现hashCode()和equals()方法、数组操作、枚举、日期和时间的处理等等。

这一组API的所有包名都以org.apache.commons.lang开头,共有如下8个包:

org.apache.commons.lang

org.apache.commons.lang.builder

org.apache.commons.lang.enum

org.apache.commons.lang.enums

org.apache.commons.lang.exception

org.apache.commons.lang.math

org.apache.commons.lang.mutable

org.apache.commons.lang.time

其中的lang.enum已不建议使用,替代它的是紧随其后的lang.enums包。 lang包主要是一些可以高度重用的Util类;lang.builder包包含了一组用于产生每个Java类中都常使用到的toString()、 hashCode()、equals()、compareTo()等等方法的构造器;lang.enums包顾名思义用于处理枚 举;lang.exception包用于处理Java标准API中的exception,为1.4之前版本提供Nested Exception功能;lang.math包用于处理数字;lang.mutable用于包装值型变量;lang.time包提供处理日期和时间的功 能。

由于Commons的包和类实在很多,不可能一个一个讲了,在接下来的专题文章中我就只分别过一下lang、lang.builder、lang.math和lang.time这几个包和常见的用法,其他的我们可以在用到时临时参考一下Javadoc。位置就在安装路径的

…\commons-lang-2.1\docs\api\index.html

我们首先来看org.apache.commons.lang包,这个包提供了一些有用的包含static方法的Util类。除了6个Exception类和2个已经deprecated的数字类之外,commons.lang包共包含了17个实用的类:

ArrayUtils – 用于对数组的操作,如添加、查找、删除、子数组、倒序、元素类型转换等;

BitField – 用于操作位元,提供了一些方便而安全的方法;

BooleanUtils – 用于操作和转换boolean或者Boolean及相应的数组;

CharEncoding – 包含了Java环境支持的字符编码,提供是否支持某种编码的判断;

CharRange – 用于设定字符范围并做相应检查;

CharSet – 用于设定一组字符作为范围并做相应检查;

CharSetUtils – 用于操作CharSet;

CharUtils – 用于操作char值和Character对象;

ClassUtils – 用于对Java类的操作,不使用反射;

ObjectUtils – 用于操作Java对象,提供null安全的访问和其他一些功能;

RandomStringUtils – 用于生成随机的字符串;

SerializationUtils – 用于处理对象序列化,提供比一般Java序列化更高级的处理能力;

StringEscapeUtils – 用于正确处理转义字符,产生正确的Java、JavaScript、HTML、XML和SQL代码;

StringUtils – 处理String的核心类,提供了相当多的功能;

SystemUtils – 在java.lang.System基础上提供更方便的访问,如用户路径、Java版本、时区、操作系统等判断;

Validate – 提供验证的操作,有点类似assert断言;

WordUtils – 用于处理单词大小写、换行等。

下面讲下最常用的两个类

ArrayUtils

数组是我们经常需要使用到的一种数据结构,但是由于Java本身并没有提供很好的API支持,使得很多操作实际上做起来相当繁琐,以至于我们实际编 码中甚至会不惜牺牲性能去使用Collections API,用Collection当然能够很方便的解决我们的问题,但是我们一定要以性能为代价吗?ArrayUtils帮我们解决了处理类似情况的大部分 问题。来看一个例子:

view plaincopy to clipboardprint?
package sean.study.jakarta.commons.lang; 

import java.util.Map; 

import org.apache.commons.lang.ArrayUtils; 

public class ArrayUtilsUsage { 

 public static void main(String[] args) { 

  // data setup 

  int[] intArray1 = { 2, 4, 8, 16 }; 

  int[][] intArray2 = { { 1, 2 }, { 2, 4 }, { 3, 8 }, { 4, 16 } }; 

  Object[][] notAMap = { 

    { "A", new Double(100) }, 

    { "B", new Double(80) }, 

    { "C", new Double(60) }, 

    { "D", new Double(40) }, 

    { "E", new Double(20) } 

  }; 

  // printing arrays 

  System.out.println("intArray1: " + ArrayUtils.toString(intArray1)); 

  System.out.println("intArray2: " + ArrayUtils.toString(intArray2)); 

  System.out.println("notAMap: " + ArrayUtils.toString(notAMap)); 

  // finding items 

  System.out.println("intArray1 contains '8'? " 

    + ArrayUtils.contains(intArray1, 8)); 

  System.out.println("intArray1 index of '8'? " 

    + ArrayUtils.indexOf(intArray1, 8)); 

  System.out.println("intArray1 last index of '8'? " 

    + ArrayUtils.lastIndexOf(intArray1, 8)); 

  // cloning and resversing 

  int[] intArray3 = ArrayUtils.clone(intArray1); 

  System.out.println("intArray3: " + ArrayUtils.toString(intArray3)); 

  ArrayUtils.reverse(intArray3); 

  System.out.println("intArray3 reversed: " 

    + ArrayUtils.toString(intArray3)); 

  // primitive to Object array 

  Integer[] integerArray1 = ArrayUtils.toObject(intArray1); 

  System.out.println("integerArray1: " 

    + ArrayUtils.toString(integerArray1)); 

  // build Map from two dimensional array 

  Map map = ArrayUtils.toMap(notAMap); 

  Double res = (Double) map.get("C"); 

  System.out.println("get 'C' from map: " + res); 

 } 

}

以下是运行结果:   
intArray1: {2,4,8,16}   
intArray2: {{1,2},{2,4},{3,8},{4,16}}   
notAMap: {{A,100.0},{B,80.0},{C,60.0},{D,40.0},{E,20.0}}   
intArray1 contains '8'? true  
intArray1 index of '8'? 2  
intArray1 last index of '8'? 2  
intArray3: {2,4,8,16}   
intArray3 reversed: {16,8,4,2}   
integerArray1: {2,4,8,16}   
get 'C' from map: 60.0

package sean.study.jakarta.commons.lang;

import java.util.Map;

import org.apache.commons.lang.ArrayUtils;

public class ArrayUtilsUsage {

 public static void main(String[] args) {

  // data setup

  int[] intArray1 = { 2, 4, 8, 16 };

  int[][] intArray2 = { { 1, 2 }, { 2, 4 }, { 3, 8 }, { 4, 16 } };

  Object[][] notAMap = {

    { "A", new Double(100) },

    { "B", new Double(80) },

    { "C", new Double(60) },

    { "D", new Double(40) },

    { "E", new Double(20) }

  };

  // printing arrays

  System.out.println("intArray1: " + ArrayUtils.toString(intArray1));

  System.out.println("intArray2: " + ArrayUtils.toString(intArray2));

  System.out.println("notAMap: " + ArrayUtils.toString(notAMap));

  // finding items

  System.out.println("intArray1 contains '8'? "

    + ArrayUtils.contains(intArray1, 8));

  System.out.println("intArray1 index of '8'? "

    + ArrayUtils.indexOf(intArray1, 8));

  System.out.println("intArray1 last index of '8'? "

    + ArrayUtils.lastIndexOf(intArray1, 8));

  // cloning and resversing

  int[] intArray3 = ArrayUtils.clone(intArray1);

  System.out.println("intArray3: " + ArrayUtils.toString(intArray3));

  ArrayUtils.reverse(intArray3);

  System.out.println("intArray3 reversed: "

    + ArrayUtils.toString(intArray3));

  // primitive to Object array

  Integer[] integerArray1 = ArrayUtils.toObject(intArray1);

  System.out.println("integerArray1: "

    + ArrayUtils.toString(integerArray1));

  // build Map from two dimensional array

  Map map = ArrayUtils.toMap(notAMap);

  Double res = (Double) map.get("C");

  System.out.println("get 'C' from map: " + res);

 }

}

以下是运行结果:

intArray1: {2,4,8,16}

intArray2: {{1,2},{2,4},{3,8},{4,16}}

notAMap: {{A,100.0},{B,80.0},{C,60.0},{D,40.0},{E,20.0}}

intArray1 contains '8'? true

intArray1 index of '8'? 2

intArray1 last index of '8'? 2

intArray3: {2,4,8,16}

intArray3 reversed: {16,8,4,2}

integerArray1: {2,4,8,16}

get 'C' from map: 60.0

这段代码说明了我们可以如何方便的利用ArrayUtils类帮我们完成数组的打印、查找、克隆、倒序、以及值型/对象数组之间的转换等操作。

StringUtils

处理文本对Java应用来说应该算是家常便饭了,在1.4出现之前,Java自身提供的API非常有限,如String、 StringTokenizer、StringBuffer,操作也比较单一。无非就是查找substring、分解、合并等等。到1.4的出现可以说 Java的文字处理上了一个台阶,因为它支持regular expression了。这可是个重量级而方便的东东啊,缺点是太复杂,学习起来有一定难度。相较而言,Jakarta Commons提供的StringUtils和WordUtils至今还维持着那种简洁而强大的美,使用起来也很顺手。来看一个例子:

view plaincopy to clipboardprint?
package sean.study.jakarta.commons.lang; 

import org.apache.commons.lang.StringUtils; 

public class StringUtilsAndWordUtilsUsage { 

 public static void main(String[] args) { 

  // data setup 

  String str1 = ""; 

  String str2 = " "; 

  String str3 = "\t"; 

  String str4 = null; 

  String str5 = "123"; 

  String str6 = "ABCDEFG"; 

  String str7 = "It feels good to use Jakarta Commons.\r\n"; 

  // check for empty strings 

  System.out.println("=============================="); 

  System.out.println("Is str1 blank? " + StringUtils.isBlank(str1)); 

  System.out.println("Is str2 blank? " + StringUtils.isBlank(str2)); 

  System.out.println("Is str3 blank? " + StringUtils.isBlank(str3)); 

  System.out.println("Is str4 blank? " + StringUtils.isBlank(str4)); 

  // check for numerics 

  System.out.println("=============================="); 

  System.out.println("Is str5 numeric? " + StringUtils.isNumeric(str5)); 

  System.out.println("Is str6 numeric? " + StringUtils.isNumeric(str6)); 

  // reverse strings / whole words 

  System.out.println("=============================="); 

  System.out.println("str6: " + str6); 

  System.out.println("str6 reversed: " + StringUtils.reverse(str6)); 

  System.out.println("str7: " + str7); 

  String str8 = StringUtils.chomp(str7); 

  str8 = StringUtils.reverseDelimited(str8, ' '); 

  System.out.println("str7 reversed whole words : \r\n" + str8); 

  // build header (useful to print log messages that are easy to locate) 

  System.out.println("=============================="); 

  System.out.println("print header:"); 

  String padding = StringUtils.repeat("=", 50); 

  String msg = StringUtils.center(" Customised Header ", 50, "%"); 

  Object[] raw = new Object[]{padding, msg, padding}; 

  String header = StringUtils.join(raw, "\r\n"); 

  System.out.println(header); 

 } 

}

输出的结果如下:   
==============================   
  
Is str1 blank? true  
  
Is str2 blank? true  
  
Is str3 blank? true  
  
Is str4 blank? true  
  
==============================   
  
Is str5 numeric? true  
  
Is str6 numeric? false  
  
==============================   
  
str6: ABCDEFG   
  
str6 reversed: GFEDCBA   
  
str7: It feels good to use Jakarta Commons.   
  
    
  
str7 reversed whole words :    
  
Commons. Jakarta use to good feels It   
  
==============================   
  
print header:   
  
==================================================   
  
%%%%%%%%%%%%%%% Customised Header %%%%%%%%%%%%%%%%   
  
==================================================

package sean.study.jakarta.commons.lang;

import org.apache.commons.lang.StringUtils;

public class StringUtilsAndWordUtilsUsage {

 public static void main(String[] args) {

  // data setup

  String str1 = "";

  String str2 = " ";

  String str3 = "\t";

  String str4 = null;

  String str5 = "123";

  String str6 = "ABCDEFG";

  String str7 = "It feels good to use Jakarta Commons.\r\n";

  // check for empty strings

  System.out.println("==============================");

  System.out.println("Is str1 blank? " + StringUtils.isBlank(str1));

  System.out.println("Is str2 blank? " + StringUtils.isBlank(str2));

  System.out.println("Is str3 blank? " + StringUtils.isBlank(str3));

  System.out.println("Is str4 blank? " + StringUtils.isBlank(str4));

  // check for numerics

  System.out.println("==============================");

  System.out.println("Is str5 numeric? " + StringUtils.isNumeric(str5));

  System.out.println("Is str6 numeric? " + StringUtils.isNumeric(str6));

  // reverse strings / whole words

  System.out.println("==============================");

  System.out.println("str6: " + str6);

  System.out.println("str6 reversed: " + StringUtils.reverse(str6));

  System.out.println("str7: " + str7);

  String str8 = StringUtils.chomp(str7);

  str8 = StringUtils.reverseDelimited(str8, ' ');

  System.out.println("str7 reversed whole words : \r\n" + str8);

  // build header (useful to print log messages that are easy to locate)

  System.out.println("==============================");

  System.out.println("print header:");

  String padding = StringUtils.repeat("=", 50);

  String msg = StringUtils.center(" Customised Header ", 50, "%");

  Object[] raw = new Object[]{padding, msg, padding};

  String header = StringUtils.join(raw, "\r\n");

  System.out.println(header);

 }

}

输出的结果如下:

==============================

Is str1 blank? true

Is str2 blank? true

Is str3 blank? true

Is str4 blank? true

==============================

Is str5 numeric? true

Is str6 numeric? false

==============================

str6: ABCDEFG

str6 reversed: GFEDCBA

str7: It feels good to use Jakarta Commons.

str7 reversed whole words :

Commons. Jakarta use to good feels It

==============================

print header:

==================================================

%%%%%%%%%%%%%%% Customised Header %%%%%%%%%%%%%%%%

==================================================

从代码中我们可以大致了解到这个StringUtils类简单而强大的处理能力,从检查空串(对null的情况处理很得体),到分割子串,到生成格式化的字符串,使用都很简洁,也很直截了当。

总结

以上就是本文的全部内容,希望对大家有所帮助。

(0)

相关推荐

  • Android编程中的四大基本组件与生命周期详解

    本文实例讲述了Android编程中的四大基本组件与生命周期.分享给大家供大家参考,具体如下: Android四大基本组件分别是Activity,Service服务,Content Provider内容提供者,BroadcastReceiver广播接收器. 一:了解四大基本组件 Activity : 应用程序中,一个Activity通常就是一个单独的屏幕,它上面可以显示一些控件也可以监听并处理用户的事件做出响应. Activity之间通过Intent进行通信.在Intent 的描述结构中,有两个最

  • Android编程四大组件之BroadcastReceiver(广播接收者)用法实例

    本文实例讲述了Android编程四大组件之BroadcastReceiver(广播接收者)用法.分享给大家供大家参考,具体如下: 这里介绍如何创建广播.如何发送一个无序广播和有序广播.以及监听短信以及监听呼出电话(当我们发短信和打电话,系统就会发一个广播,我们可以拦截此广播进行监听短信以及监听呼出电话). 定义广播接收者 1.定义类继承BroadcastReceiver,重写onReceive方法 2.当接收到匹配广播之后就会执行onReceive方法 3.清单文件中声明<receiver>,

  • ExtJS4 组件化编程,动态加载,面向对象,Direct

    ExtJS4推荐定义类的时候均使用Ext.define,利用xtype动态加载 修改了以前的一个登陆窗口,感觉用官方推荐的方法还是很不错的 但还有一些问题没有想得非常清楚,先把代码贴出来一起研究下.请看代码中的注释~~ 使用Ext+.Net,用Direct模式传递数据 Default.aspx: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3

  • C++ COM编程之什么是组件?

    什么是组件? 一个组件同一个微型应用程序类似,即都是已经编译.链接好并可以使用的了,应用程序就是由多个这样的组件打包而得到的.各定制的组件可以在运行时同其他组件连接起来以构成某个应用程序.在需要对应用程序进行修改或改进时,只需要将构成此应用程序的组件中的某个用新的版本替换掉即可. COM组件 COM,即组件对象模型,是一个说明如何建立可动态互变组件的规范,它提供了为保证能够互操作,客户和组件应遵循的一些标准. COM组件是以Win32动态链接库(DLLs)或可执行文件(EXEs)的形式发布的可执

  • PHP 组件化编程技巧

    但其在UI方便却有些力不从心,不仅是PHP,任何一种Web编程语言在设计UI都有类似的问题,宿主语言与HTML混和在一个文件中,大量重复的 HTML代码,毫无任何技术含量,但又非常的费时费力.于是我就希望能够对之前做过的PHP项目UI部分进行总结和归纳,将其封装为一个个小的组件(就像 Delphi中的组件一样),在界面上呈现为统一的风格,日后可以再针对这结组件编写多个CSS文件,提供"换肤"功能. 所有的组件都继承自AbatractComponent这个类,并实现其中的toString

  • Java编程Commons lang组件简介

    跟java.lang这个包的作用类似,Commons Lang这一组API也是提供一些基础的.通用的操作和处理,如自动生成toString()的结果.自动实现hashCode()和equals()方法.数组操作.枚举.日期和时间的处理等等. 这一组API的所有包名都以org.apache.commons.lang开头,共有如下8个包: org.apache.commons.lang org.apache.commons.lang.builder org.apache.commons.lang.e

  • Commons beanutils组件简介

    Commons Beanutils是Apache开源组织提供的用于操作JAVA BEAN的工具包.使用commons beanutils,我们可以很方便的对bean对象的属性进行操作.今天为大家介绍一下该包的常用方法. 1.什么是BeanUtils 程序中对javabean的操作很频繁, 所以apache提供了一套开源的api,方便对javabean的操作,即BeanUtils组件. 2.BeanUtils的作用 简化javabean的操作. 在一般的写bean组件的时候,都必须要写setter

  • Java编程swing组件JLabel详解以及使用示例

    JLabel 对象可以显示文本.图像或同时显示二者.可以通过设置垂直和水平对齐方式,指定标签显示区中标签内容在何处对齐.默认情况下,标签在其显示区内垂直居中对齐.默认情况下,只显示文本的标签是开始边对齐:而只显示图像的标签则水平居中对齐. 还可以指定文本相对于图像的位置.默认情况下,文本位于图像的结尾边上,文本和图像都垂直对齐. 构造方法介绍: JLabel() 创建无图像并且其标题为空字符串的 JLabel. JLabel(Icon image) 创建具有指定图像的 JLabel 实例. JL

  • Java编程使用箱式布局管理器示例【基于swing组件】

    本文实例讲述了Java编程使用箱式布局管理器.分享给大家供大家参考,具体如下: 先来看看运行效果: 完整代码如下: package awtDemo; import java.awt.BorderLayout; import java.awt.Container; import javax.swing.Box; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax

  • Java编程使用卡片布局管理器示例【基于swing组件】

    本文实例讲述了Java编程使用卡片布局管理器.分享给大家供大家参考,具体如下: 运行效果: 完整示例代码: package com.han; import java.awt.BorderLayout; import java.awt.CardLayout; import java.awt.Container; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.JB

  • java编程SpringSecurity入门原理及应用简介

    目录 1. SpringSecurity 框架简介 1.1 概要 1.2 组成以及同款产品(shiro)对比 1.2.1 Spring Security 1.2.2 Shiro 1.3 模块划分 1.4 SpringSecurity 基本原理 1.5.UserDetailsService 接口讲解 2.SpringSecurity Web 权限方案 2.1设置登录系统的账号密码(三种方式) 设计数据库表 建立springboot项目,勾选相应依赖 完整pom.xml 数据库配置 创建对应的实体类

  • Java中使用fileupload组件实现文件上传功能的实例代码

    使用fileupload组件的原因: Request对象提供了一个getInputStream()方法,通过这个方法可以读取到客户端提交过来的数据,但是由于用户可能会同时上传多个文件,在servlet中编程解析这些上传数据是一件非常麻烦的工作.为方便开发人员处理文件上传数据,Apache开源组织提供了一个用来处理表单文件上传的一个开源组件(Commons-fileupload),该组件性能优异,并且使用及其简单,可以让开发人员轻松实现web文件上传功能. 使用Commons-fileupload

  • Java编程ssh整合常见错误解析

    1. org.springframework.transaction.CannotCreateTransactionException: Could not open JPA EntityManager for transaction; nested exception is java.lang.UnsupportedOperationException: Not supported by BasicDataSource Spring不能为JAP创建事务.原因是bean.xml设定了数据源per

  • Java编程中避免equals方法的隐藏陷阱介绍

    摘要 本文描述重载equals方法的技术,这种技术即使是具现类的子类增加了字段也能保证equal语义的正确性. 在<Effective Java>的第8项中,Josh Bloch描述了当继承类作为面向对象语言中的等价关系的基础问题,要保证派生类的equal正确性语义所会面对的困难.Bloch这样写到: 除非你忘记了面向对象抽象的好处,否则在当你继承一个新类或在类中增加了一个值组件时你无法同时保证equal的语义依然正确 在<Programming in Scala>中的第28章演示

  • java分布式面试降级组件Hystrix的功能特性

    目录 引言 1.面试官:能简单介绍下Hystrix有哪些功能吗? 1.1.fail-fast(快速失败) 1.2.Fallback优雅降级机制 1.3.线程/信号量隔离机制 线程隔离: 信号量隔离: 2.面试官:刚刚说到线程隔离,那实际使用中是否打开超时线程中断开关? 3.面试官:那你是如何估计线程池大小的? 深入分析 Hystrix历史 Hystrix的主要功能特性 HystrixDemo 哪些情况下会触发fallback? 附录:Hystrix策略配置 Sentinel与Hystrixres

随机推荐