1.求shop++的源代码
2.程序员的福音 - Apache Commons Lang
3.你知道ApacheCommon包中isNumeric方法是坑吗?
4.StringUtilså¨commons-lang3åcommons-langä¸çåºå«
5.别再用 System.currentTimeMillis() 统计耗时了,太 Low,StopWatch 好用到爆!
求shop++的源代码
主要库
spring-aop-4.0.9.RELEASE
spring-beans-4.0.9.RELEASE
spring-context-4.0.9.RELEASE
spring-context-support-4.0.9.RELEASE
spring-core-4.0.9.RELEASE
spring-expression-4.0.9.RELEASE
spring-jdbc-4.0.9.RELEASE
spring-orm-4.0.9.RELEASE
spring-test-4.0.9.RELEASE
spring-tx-4.0.9.RELEASE
spring-web-4.0.9.RELEASE
spring-webmvc-4.0.9.RELEASE
hibernate-core-4.3.9.Final
hibernate-jpa-2.1-api-1.0.0.Final
hibernate-entitymanager-4.3.9.Final
hibernate-validator-5.1.3.Final
hibernate-search-orm-4.5.3.Final
lucene-core-3.6.2
freemarker-2.3.
ehcache-core-2.6.
ehcache-web-2.0.4
shiro-core-1.2.3
shiro-web-1.2.3
c3p0-0.9.2.1
commons-lang-2.6
commons-beanutils-1.9.2
commons-collections-3.2.1
commons-io-2.4
commons-net-3.3
commons-fileupload-1.3.1
commons-codec-1.
commons-email-1.3.3
commons-compress-1.9
junit-4.
mons工具包中,Lang包是最常用的。
目前Lang包包括commons-lang3和commons-lang两个版本。单页广告源码Lang的最新版本为2.6,适用于Java1.2及以上环境,但官方已不再维护。Lang3的最新版本为3..0,适用于Java8及以上环境,完全支持Java8的特性,并废弃了一些旧的API。由于版本不兼容,ftp源码如何上传Lang3更名为lang3以避免冲突。
推荐Java8以上的用户使用lang3代替lang。以下内容以lang3 - 3..0版本为例进行说明。
以下是整体结构:
以下仅列举其中常用功能进行说明,其余功能可自行查阅源码研究。
. 日期相关:在Java8之前,日期处理主要依赖于java.util.Date和java.util.Calendar类,但这两个API存在线程安全问题且不够便捷。Java8推出了新的日期API。如果仍在使用旧的日期API,可以使用DateUtils和DateFormatUtils工具类进行转换和计算。
. 字符串相关:字符串是Java中最常用的类型,相关工具类也最为常用。在线代码编译源码以下列举了一些常用功能:
1. 字符串判空
2. 字符串去空格
3. 字符串分割
4. 取子字符串
5. 其他功能
6. 随机字符串
. 反射相关:反射是Java的重要特性,Lang包中的反射工具类可以方便地实现反射功能。以下列举了一些常用功能:
1. 属性操作
注:方法名含Declared的只会在当前类实例上寻找,不包含Declared的在当前类上找不到则会递归向父类上一直查找。
2. 获取注解方法
3. 方法调用
其他还有ClassUtils,ConstructorUtils,TypeUtils等,不是很常用,有需求的可以现查阅类的源码。
. 系统相关:主要获取操作系统和JVM的一些信息。
. 总结:除了以上介绍的工具类外,还有其他不常用的工具类。感兴趣的限制ip地址源码用户可以自行查阅源码研究。
你知道ApacheCommon包中isNumeric方法是坑吗?
使用的Apache-Common包的版本是commons-lang-2.6.jar
本文就来分享一个这个坑的情况,以免其它tx也掉坑中
费话不多说,来看代码: package chapter4; import org.apache.commons.lang.StringUtils; /** * Created by MyWorld on /3/. */ public class StringUtilsIsNumericChecker { public static void main(String[] args) { System.out.println(StringUtils.isNumeric("1")); System.out.println(StringUtils.isNumeric("-1")); } }
围观的tx,认为上面api的输出结果会是什么呢?两个true? 好吧,执行一行看看结果: true false
什么情况,-1不是数字吗? 为什么是false呢 来分析下源码: public static boolean isNumeric(String str) { if (str == null) { return false; } int sz = str.length(); for (int i = 0; i sz; i++) { if (Character.isDigit(str.charAt(i)) == false) { return false; } } return true; }
源码中判断是否数字的依据是JDK的API: java.lang.Character.isDigit(str.charAt(i)) 看看个API的源码: public static boolean isDigit(char ch) { return isDigit((int)ch); }
看看isDigit(int codePoint)的源码: public static boolean isDigit(int codePoint) { boolean bDigit = false; if (codePoint = MIN_CODE_POINT codePoint = FAST_PATH_MAX) { bDigit = CharacterDataLatin1.isDigit(codePoint); } else { int plane = getPlane(codePoint); switch(plane) { case(0): bDigit = CharacterData.isDigit(codePoint); break; case(1): bDigit = CharacterData.isDigit(codePoint); break; case(2): bDigit = CharacterData.isDigit(codePoint); break; case(3): // Undefined case(4): // Undefined case(5): // Undefined case(6): // Undefined case(7): // Undefined case(8): // Undefined case(9): // Undefined case(): // Undefined case(): // Undefined case(): // Undefined case(): // Undefined bDigit = CharacterDataUndefined.isDigit(codePoint); break; case(): bDigit = CharacterData0E.isDigit(codePoint); break; case(): // Private Use case(): // Private Use bDigit = CharacterDataPrivateUse.isDigit(codePoint); break; default: // the argument's plane is invalid, and thus is an invalid codepoint // bDigit remains false; break; } } return bDigit; }
下面还有更深的调用,貌似还涉及到ASCII码了。 水太深,就不继续看了。 有一点是肯定的,这个API不是通过类似Regex expression的方式来判断是数字,而通过每个字符的ASCII的值类确定的 回到API的isNumeric(String str), 看看Doc是jdk源码反编译怎么说的: /** * pChecks if the String contains only unicode digits. * A decimal point is not a unicode digit and returns false./p * * pcodenull/code will return codefalse/code. * An empty String (length()=0) will return codetrue/code./p * * pre * StringUtils.isNumeric(null) = false * StringUtils.isNumeric("") = true * StringUtils.isNumeric(" ") = false * StringUtils.isNumeric("") = true * StringUtils.isNumeric(" 3") = false * StringUtils.isNumeric("ab2c") = false * StringUtils.isNumeric("-3") = false * StringUtils.isNumeric(".3") = false * /pre * * @param str the String to check, may be null * @return codetrue/code if only contains digits, and is non-null */
看完上面的Doc,感觉水好深。 这个API的方法名直接命名为isInt不就完了。方法名很容易误导人 这也是给开发的tx敲了一个警钟, api使用之前一定要确认清楚,至少看看Doc文档吧
StringUtilså¨commons-lang3åcommons-langä¸çåºå«
ï¼1ï¼å ¥åç±»åä¸åcommons.langä¸å ¥å为 Sring str
commons.lang3ä¸å ¥å为 CharSequence cs(éç¨èå´æ´å¹¿)
ï¼2ï¼å ¥åæ°éä¸å
commons.lang3ä¸æ¯æå¤å ¥å
æè¿ç»å¸¸éè¦å¯¹Stringåä¸äºå¤æåå¤çï¼äºæ¯å°±ç¨å°äºApacheæä¾çStringUtilsè¿ä¸ªå·¥å ·ç±»ï¼ç¨çæ¶ååç°æ两个ä¸åççæ¬ï¼ä¸ä¸ªçæ¬ä½äºorg.apache.commons.langä¸é¢ï¼å¦ä¸ä¸ªåä½äºorg.apache.commons.lang3ä¸é¢ã
æ¥äºä¸ä¸èµæï¼lang3æ¯Apache Commons å¢éåå¸çå·¥å ·å ï¼è¦æ±jdkçæ¬å¨1.5以ä¸ï¼ç¸å¯¹äºlangæ¥è¯´å®å ¨æ¯æjava5çç¹æ§ï¼åºé¤äºä¸äºæ§çAPIã该çæ¬æ æ³å ¼å®¹æ§æçæ¬ï¼äºæ¯ä¸ºäºé¿å å²çªæ¹å为lang3ãè¿äºä¸è¥¿å°±ä¸åç»è¯´äºï¼æ们æ¥ççStringUtilsä¸å¸¸ç¨çä¸äºæ¹æ³æä»ä¹æ¹åå§ã
å¯ä»¥çå°è¿å 个æ¹æ³é»è¾æ¯«æ ååï¼åªæ¯åæ°ç±»ååäºï¼ç±Stringå为CharSequenceãé£ä¹è¿ä¸ªCharSequenceæ¯ä»ä¹å¢ï¼æ们ççå®çæºç ï¼
CharSequenceæ¯ä¸ä¸ªå符åºåçæ¥å£ï¼å ¶ä¸å®ä¹äºä¸äºå¸¸ç¨çå¦length()ãsubSequence()çæ¹æ³ï¼Stringä¹å®ç°äºè¿ä¸ªæ¥å£ãå½ç¶å¤§å®¶å¯è½å¨Stringéç¨å°çé½æ¯subString()ï¼å®é ä¸Stringä¹å®ç°äºsubSequence()è¿ä¸ªæ¹æ³ï¼åªæ¯ç´æ¥æåäºsubString()ã
lang3ä¸ä½¿ç¨CharSequenceæ大ç好å¤å°±æ¯ä»¤è¿äºæ¹æ³ç¨å¤æ´å 广æ³ï¼ä¸æ¢å±éäºStringï¼å ¶ä»ä¸äºå®ç°äºè¯¥æ¥å£çç±»ä¹å¯ä»¥ä½¿ç¨StringUtilsä¸çè¿äºæ¹æ³å»è¿è¡ä¸äºæä½ãå¦å¤æåç°å¾å¤nioä¸çç±»é½å®ç°äºè¿ä¸ªæ¥å£ï¼ä¸ªäººçæµå¯è½ä¹æ为nioæå¡çç®çã
å¨langä¸ï¼ç¬¬ä¸æ¥æ¯å å¤æstr1æ¯å¦ä¸ºç©ºï¼èå¨lang3ä¸ï¼ç¬¬ä¸æ¥åæ¯å å¤æ两个对象æ¯å¦ç¸åãè¿ä¸ªä¸é¾ç解ï¼å¦æ两个对象çå°åç¸åï¼é£ä¹å®ä»¬æåçå°±æ¯åä¸ä¸ªå¯¹è±¡ï¼å 容è¯å®ç¸åã
å¨lang3ä¸ï¼è¿å å ¥äºä¸äºåæ¶å¤æå¤ä¸ªåæ°çæ¹æ³ï¼å¯ä»¥çå°å®é ä¸æ¯å°åæ°å表æ¾å ¥ä¸ä¸ªCharSequenceæ°ç»ä¸ï¼ç¶åéåè°ç¨ä¹åçisEmptyçæ¹æ³ãå¤æblankä¹æ类似çæ¹æ³ã
å¯è½æ人ä¼è§å¾ï¼å¾å¤æ¹æ³Stringæ¬èº«å°±æåï¼ä¸ºä»ä¹è¿è¦ç¨StringUtilsæä¾çå¢ï¼æå¼åæ°ç±»åä¸è°ï¼æ们å¯ä»¥çå°ï¼StringUtilsä¸çæ¹æ³å¤§å¤é½åäºç©ºæ ¡éªï¼å¦æ为空æ¶ä¼è¿åNullæè 空串ï¼èStringæ¬èº«çæ¹æ³å¨å¾å¤ä¼ å ¥åæ°æ对象æ¬èº«ä¸ºç©ºçæ¶åé½ä¼æ¥ç©ºæéé误ã
åèå°åï¼ StringUtilså¨commons-lang3åcommons-langä¸çåºå«
别再用 System.currentTimeMillis() 统计耗时了,太 Low,StopWatch 好用到爆!
你是否还在用 System.currentTimeMillis... 来统计耗时?其实,这已不再是最优选择。StopWatch 工具类提供了更为简便且强大的耗时统计方式。
StopWatch 工具类在 Java 中被广泛使用,它能够帮助你轻松完成多个任务的计时与总耗时统计,不再需要手工计算,避免了可能的逻辑错误。
两个常用的 StopWatch 工具类名称相同,但它们的用法大相径庭。本文将为你详细介绍如何使用它们。
在 Apache 开源的通用工具包 commons-lang3 中,你需要额外引入 Maven 依赖来使用 StopWatch。以下是创建 StopWatch 实例的三种方法:
1. 使用 new 关键字
2. 使用 create 工厂方法
3. 使用 createStarted 方法,此方法会同时创建实例并启动计时。
下面是一个简单的示例:
在使用 StopWatch 时,你可以暂停、恢复、停止计时以及重置计时。本文将通过具体示例来演示这些功能。
为了便于理解,我们将继续演示上述示例,并对其中的计时过程进行详细说明。
为了帮助你更好地掌握 StopWatch 的使用,本文提供了所有完整示例的源代码,你可以在 Github 上查看。欢迎你将代码 Star 学习,后续的 Java 示例也将在此平台上提供。
如果你的项目使用了 Spring 框架,Spring 也提供了一个 StopWatch 工具类。接下来,我们将通过一个简单的例子来介绍 Spring 中的 StopWatch,并展示其功能。
Spring 提供的 StopWatch 让你能够手动开始和停止计时,并且可以按格式化打印结果。此外,它还支持为每个子任务添加名称,使得多任务统计时更为直观。
在深入研究 StopWatch 的核心源码后,你会发现其实它们都基于 JDK 的 System 类进行了封装。
总结而言,commons-lang3 和 Spring 框架中的 StopWatch 都能高效完成耗时统计任务。它们各有优缺点,而灵活与强大则是commons-lang3 的优势所在。Spring 则提供了额外的功能,如格式化打印结果和子任务名称,使其在多任务统计时更为便捷。
总的来说,推荐使用 commons-lang3 工具包中的 StopWatch。如果项目需要额外引入依赖,Spring 中的 StopWatch 也是一个不错的选择。希望你能在统计耗时时做出更明智的选择,并与他人分享。记住,别再用手工计算耗时了,选择 StopWatch,让你的代码更加专业和高效。
本文的所有示例代码已上传至 Github,欢迎你 Star 学习。后续更多 Java 技术分享和最新资讯将在 Java 技术栈公众号上发布,记得关注以获取最新信息。