Java工作中常用工具类总结一
来源:互联网 发布:淘宝葡萄酒 编辑:程序博客网 时间:2024/05/16 14:17
一、String工具类
- package com.mkyong.common;
- import java.util.ArrayList;
- import java.util.List;
- /**
- *
- * String工具类. <br>
- *
- * @author 宋立君
- * @date 2014年06月24日
- */
- public class StringUtil {
- private static final int INDEX_NOT_FOUND = -1;
- private static final String EMPTY = "";
- /**
- * <p>
- * The maximum size to which the padding constant(s) can expand.
- * </p>
- */
- private static final int PAD_LIMIT = 8192;
- /**
- * 功能:将半角的符号转换成全角符号.(即英文字符转中文字符)
- *
- * @author 宋立君
- * @param str
- * 源字符串
- * @return String
- * @date 2014年06月24日
- */
- public static String changeToFull(String str) {
- String source = "1234567890!@#$%^&*()abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_=+\\|[];:'\",<.>/?";
- String[] decode = { "1", "2", "3", "4", "5", "6", "7", "8", "9", "0",
- "!", "@", "#", "$", "%", "︿", "&", "*", "(", ")", "a", "b",
- "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n",
- "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z",
- "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L",
- "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X",
- "Y", "Z", "-", "_", "=", "+", "\", "|", "【", "】", ";", ":",
- "'", "\"", ",", "〈", "。", "〉", "/", "?" };
- String result = "";
- for (int i = 0; i < str.length(); i++) {
- int pos = source.indexOf(str.charAt(i));
- if (pos != -1) {
- result += decode[pos];
- } else {
- result += str.charAt(i);
- }
- }
- return result;
- }
- /**
- * 功能:cs串中是否一个都不包含字符数组searchChars中的字符。
- *
- * @author 宋立君
- * @param cs
- * 字符串
- * @param searchChars
- * 字符数组
- * @return boolean 都不包含返回true,否则返回false。
- * @date 2014年06月24日
- */
- public static boolean containsNone(CharSequence cs, char... searchChars) {
- if (cs == null || searchChars == null) {
- return true;
- }
- int csLen = cs.length();
- int csLast = csLen - 1;
- int searchLen = searchChars.length;
- int searchLast = searchLen - 1;
- for (int i = 0; i < csLen; i++) {
- char ch = cs.charAt(i);
- for (int j = 0; j < searchLen; j++) {
- if (searchChars[j] == ch) {
- if (Character.isHighSurrogate(ch)) {
- if (j == searchLast) {
- // missing low surrogate, fine, like
- // String.indexOf(String)
- return false;
- }
- if (i < csLast
- && searchChars[j + 1] == cs.charAt(i + 1)) {
- return false;
- }
- } else {
- // ch is in the Basic Multilingual Plane
- return false;
- }
- }
- }
- }
- return true;
- }
- /**
- * <p>
- * 编码为Unicode,格式 '\u0020'.
- * </p>
- *
- * @author 宋立君
- *
- * <pre>
- * CharUtils.unicodeEscaped(' ') = "\u0020"
- * CharUtils.unicodeEscaped('A') = "\u0041"
- * </pre>
- *
- * @param ch
- * 源字符串
- * @return 转码后的字符串
- * @date 2014年06月24日
- */
- public static String unicodeEscaped(char ch) {
- if (ch < 0x10) {
- return "\\u000" + Integer.toHexString(ch);
- } else if (ch < 0x100) {
- return "\\u00" + Integer.toHexString(ch);
- } else if (ch < 0x1000) {
- return "\\u0" + Integer.toHexString(ch);
- }
- return "\\u" + Integer.toHexString(ch);
- }
- /**
- * <p>
- * 进行tostring操作,如果传入的是null,返回空字符串。
- * </p>
- *
- * <pre>
- * ObjectUtils.toString(null) = ""
- * ObjectUtils.toString("") = ""
- * ObjectUtils.toString("bat") = "bat"
- * ObjectUtils.toString(Boolean.TRUE) = "true"
- * </pre>
- *
- * @param obj
- * 源
- * @return String
- */
- public static String toString(Object obj) {
- return obj == null ? "" : obj.toString();
- }
- /**
- * <p>
- * 进行tostring操作,如果传入的是null,返回指定的默认值。
- * </p>
- *
- * <pre>
- * ObjectUtils.toString(null, null) = null
- * ObjectUtils.toString(null, "null") = "null"
- * ObjectUtils.toString("", "null") = ""
- * ObjectUtils.toString("bat", "null") = "bat"
- * ObjectUtils.toString(Boolean.TRUE, "null") = "true"
- * </pre>
- *
- * @param obj
- * 源
- * @param nullStr
- * 如果obj为null时返回这个指定值
- * @return String
- */
- public static String toString(Object obj, String nullStr) {
- return obj == null ? nullStr : obj.toString();
- }
- /**
- * <p>
- * 只从源字符串中移除指定开头子字符串.
- * </p>
- *
- * <pre>
- * StringUtil.removeStart(null, *) = null
- * StringUtil.removeStart("", *) = ""
- * StringUtil.removeStart(*, null) = *
- * StringUtil.removeStart("www.domain.com", "www.") = "domain.com"
- * StringUtil.removeStart("domain.com", "www.") = "domain.com"
- * StringUtil.removeStart("www.domain.com", "domain") = "www.domain.com"
- * StringUtil.removeStart("abc", "") = "abc"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param remove
- * 将要被移除的子字符串
- * @return String
- */
- public static String removeStart(String str, String remove) {
- if (isEmpty(str) || isEmpty(remove)) {
- return str;
- }
- if (str.startsWith(remove)) {
- return str.substring(remove.length());
- }
- return str;
- }
- /**
- * <p>
- * 只从源字符串中移除指定结尾的子字符串.
- * </p>
- *
- * <pre>
- * StringUtil.removeEnd(null, *) = null
- * StringUtil.removeEnd("", *) = ""
- * StringUtil.removeEnd(*, null) = *
- * StringUtil.removeEnd("www.domain.com", ".com.") = "www.domain.com"
- * StringUtil.removeEnd("www.domain.com", ".com") = "www.domain"
- * StringUtil.removeEnd("www.domain.com", "domain") = "www.domain.com"
- * StringUtil.removeEnd("abc", "") = "abc"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param remove
- * 将要被移除的子字符串
- * @return String
- */
- public static String removeEnd(String str, String remove) {
- if (isEmpty(str) || isEmpty(remove)) {
- return str;
- }
- if (str.endsWith(remove)) {
- return str.substring(0, str.length() - remove.length());
- }
- return str;
- }
- /**
- * <p>
- * 将一个字符串重复N次
- * </p>
- *
- * <pre>
- * StringUtil.repeat(null, 2) = null
- * StringUtil.repeat("", 0) = ""
- * StringUtil.repeat("", 2) = ""
- * StringUtil.repeat("a", 3) = "aaa"
- * StringUtil.repeat("ab", 2) = "abab"
- * StringUtil.repeat("a", -2) = ""
- * </pre>
- *
- * @param str
- * 源字符串
- * @param repeat
- * 重复的次数
- * @return String
- */
- public static String repeat(String str, int repeat) {
- // Performance tuned for 2.0 (JDK1.4)
- if (str == null) {
- return null;
- }
- if (repeat <= 0) {
- return EMPTY;
- }
- int inputLength = str.length();
- if (repeat == 1 || inputLength == 0) {
- return str;
- }
- if (inputLength == 1 && repeat <= PAD_LIMIT) {
- return repeat(str.charAt(0), repeat);
- }
- int outputLength = inputLength * repeat;
- switch (inputLength) {
- case 1:
- return repeat(str.charAt(0), repeat);
- case 2:
- char ch0 = str.charAt(0);
- char ch1 = str.charAt(1);
- char[] output2 = new char[outputLength];
- for (int i = repeat * 2 - 2; i >= 0; i--, i--) {
- output2[i] = ch0;
- output2[i + 1] = ch1;
- }
- return new String(output2);
- default:
- StringBuilder buf = new StringBuilder(outputLength);
- for (int i = 0; i < repeat; i++) {
- buf.append(str);
- }
- return buf.toString();
- }
- }
- /**
- * <p>
- * 将一个字符串重复N次,并且中间加上指定的分隔符
- * </p>
- *
- * <pre>
- * StringUtil.repeat(null, null, 2) = null
- * StringUtil.repeat(null, "x", 2) = null
- * StringUtil.repeat("", null, 0) = ""
- * StringUtil.repeat("", "", 2) = ""
- * StringUtil.repeat("", "x", 3) = "xxx"
- * StringUtil.repeat("?", ", ", 3) = "?, ?, ?"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param separator
- * 分隔符
- * @param repeat
- * 重复次数
- * @return String
- */
- public static String repeat(String str, String separator, int repeat) {
- if (str == null || separator == null) {
- return repeat(str, repeat);
- } else {
- // given that repeat(String, int) is quite optimized, better to rely
- // on it than try and splice this into it
- String result = repeat(str + separator, repeat);
- return removeEnd(result, separator);
- }
- }
- /**
- * <p>
- * 将某个字符重复N次.
- * </p>
- *
- * @param ch
- * 某个字符
- * @param repeat
- * 重复次数
- * @return String
- */
- public static String repeat(char ch, int repeat) {
- char[] buf = new char[repeat];
- for (int i = repeat - 1; i >= 0; i--) {
- buf[i] = ch;
- }
- return new String(buf);
- }
- /**
- * <p>
- * 字符串长度达不到指定长度时,在字符串右边补指定的字符.
- * </p>
- *
- * <pre>
- * StringUtil.rightPad(null, *, *) = null
- * StringUtil.rightPad("", 3, 'z') = "zzz"
- * StringUtil.rightPad("bat", 3, 'z') = "bat"
- * StringUtil.rightPad("bat", 5, 'z') = "batzz"
- * StringUtil.rightPad("bat", 1, 'z') = "bat"
- * StringUtil.rightPad("bat", -1, 'z') = "bat"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 指定的长度
- * @param padChar
- * 进行补充的字符
- * @return String
- */
- public static String rightPad(String str, int size, char padChar) {
- if (str == null) {
- return null;
- }
- int pads = size - str.length();
- if (pads <= 0) {
- return str; // returns original String when possible
- }
- if (pads > PAD_LIMIT) {
- return rightPad(str, size, String.valueOf(padChar));
- }
- return str.concat(repeat(padChar, pads));
- }
- /**
- * <p>
- * 扩大字符串长度,从左边补充指定字符
- * </p>
- *
- * <pre>
- * StringUtil.rightPad(null, *, *) = null
- * StringUtil.rightPad("", 3, "z") = "zzz"
- * StringUtil.rightPad("bat", 3, "yz") = "bat"
- * StringUtil.rightPad("bat", 5, "yz") = "batyz"
- * StringUtil.rightPad("bat", 8, "yz") = "batyzyzy"
- * StringUtil.rightPad("bat", 1, "yz") = "bat"
- * StringUtil.rightPad("bat", -1, "yz") = "bat"
- * StringUtil.rightPad("bat", 5, null) = "bat "
- * StringUtil.rightPad("bat", 5, "") = "bat "
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 扩大后的长度
- * @param padStr
- * 在右边补充的字符串
- * @return String
- */
- public static String rightPad(String str, int size, String padStr) {
- if (str == null) {
- return null;
- }
- if (isEmpty(padStr)) {
- padStr = " ";
- }
- int padLen = padStr.length();
- int strLen = str.length();
- int pads = size - strLen;
- if (pads <= 0) {
- return str; // returns original String when possible
- }
- if (padLen == 1 && pads <= PAD_LIMIT) {
- return rightPad(str, size, padStr.charAt(0));
- }
- if (pads == padLen) {
- return str.concat(padStr);
- } else if (pads < padLen) {
- return str.concat(padStr.substring(0, pads));
- } else {
- char[] padding = new char[pads];
- char[] padChars = padStr.toCharArray();
- for (int i = 0; i < pads; i++) {
- padding[i] = padChars[i % padLen];
- }
- return str.concat(new String(padding));
- }
- }
- /**
- * <p>
- * 扩大字符串长度,从左边补充空格
- * </p>
- *
- * <pre>
- * StringUtil.leftPad(null, *) = null
- * StringUtil.leftPad("", 3) = " "
- * StringUtil.leftPad("bat", 3) = "bat"
- * StringUtil.leftPad("bat", 5) = " bat"
- * StringUtil.leftPad("bat", 1) = "bat"
- * StringUtil.leftPad("bat", -1) = "bat"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 扩大后的长度
- * @return String
- */
- public static String leftPad(String str, int size) {
- return leftPad(str, size, ' ');
- }
- /**
- * <p>
- * 扩大字符串长度,从左边补充指定的字符
- * </p>
- *
- * <pre>
- * StringUtil.leftPad(null, *, *) = null
- * StringUtil.leftPad("", 3, 'z') = "zzz"
- * StringUtil.leftPad("bat", 3, 'z') = "bat"
- * StringUtil.leftPad("bat", 5, 'z') = "zzbat"
- * StringUtil.leftPad("bat", 1, 'z') = "bat"
- * StringUtil.leftPad("bat", -1, 'z') = "bat"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 扩大后的长度
- * @param padStr
- * 补充的字符
- * @return String
- */
- public static String leftPad(String str, int size, char padChar) {
- if (str == null) {
- return null;
- }
- int pads = size - str.length();
- if (pads <= 0) {
- return str; // returns original String when possible
- }
- if (pads > PAD_LIMIT) {
- return leftPad(str, size, String.valueOf(padChar));
- }
- return repeat(padChar, pads).concat(str);
- }
- /**
- * <p>
- * 扩大字符串长度,从左边补充指定的字符
- * </p>
- *
- * <pre>
- * StringUtil.leftPad(null, *, *) = null
- * StringUtil.leftPad("", 3, "z") = "zzz"
- * StringUtil.leftPad("bat", 3, "yz") = "bat"
- * StringUtil.leftPad("bat", 5, "yz") = "yzbat"
- * StringUtil.leftPad("bat", 8, "yz") = "yzyzybat"
- * StringUtil.leftPad("bat", 1, "yz") = "bat"
- * StringUtil.leftPad("bat", -1, "yz") = "bat"
- * StringUtil.leftPad("bat", 5, null) = " bat"
- * StringUtil.leftPad("bat", 5, "") = " bat"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 扩大后的长度
- * @param padStr
- * 补充的字符串
- * @return String
- */
- public static String leftPad(String str, int size, String padStr) {
- if (str == null) {
- return null;
- }
- if (isEmpty(padStr)) {
- padStr = " ";
- }
- int padLen = padStr.length();
- int strLen = str.length();
- int pads = size - strLen;
- if (pads <= 0) {
- return str; // returns original String when possible
- }
- if (padLen == 1 && pads <= PAD_LIMIT) {
- return leftPad(str, size, padStr.charAt(0));
- }
- if (pads == padLen) {
- return padStr.concat(str);
- } else if (pads < padLen) {
- return padStr.substring(0, pads).concat(str);
- } else {
- char[] padding = new char[pads];
- char[] padChars = padStr.toCharArray();
- for (int i = 0; i < pads; i++) {
- padding[i] = padChars[i % padLen];
- }
- return new String(padding).concat(str);
- }
- }
- /**
- * <p>
- * 扩大字符串长度并将现在的字符串居中,被扩大部分用空格填充。
- * <p>
- *
- * <pre>
- * StringUtil.center(null, *) = null
- * StringUtil.center("", 4) = " "
- * StringUtil.center("ab", -1) = "ab"
- * StringUtil.center("ab", 4) = " ab "
- * StringUtil.center("abcd", 2) = "abcd"
- * StringUtil.center("a", 4) = " a "
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 扩大后的长度
- * @return String
- */
- public static String center(String str, int size) {
- return center(str, size, ' ');
- }
- /**
- * <p>
- * 将字符串长度修改为指定长度,并进行居中显示。
- * </p>
- *
- * <pre>
- * StringUtil.center(null, *, *) = null
- * StringUtil.center("", 4, ' ') = " "
- * StringUtil.center("ab", -1, ' ') = "ab"
- * StringUtil.center("ab", 4, ' ') = " ab"
- * StringUtil.center("abcd", 2, ' ') = "abcd"
- * StringUtil.center("a", 4, ' ') = " a "
- * StringUtil.center("a", 4, 'y') = "yayy"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 指定的长度
- * @param padStr
- * 长度不够时补充的字符串
- * @return String
- * @throws IllegalArgumentException
- * 如果被补充字符串为 null或者 empty
- */
- public static String center(String str, int size, char padChar) {
- if (str == null || size <= 0) {
- return str;
- }
- int strLen = str.length();
- int pads = size - strLen;
- if (pads <= 0) {
- return str;
- }
- str = leftPad(str, strLen + pads / 2, padChar);
- str = rightPad(str, size, padChar);
- return str;
- }
- /**
- * <p>
- * 将字符串长度修改为指定长度,并进行居中显示。
- * </p>
- *
- * <pre>
- * StringUtil.center(null, *, *) = null
- * StringUtil.center("", 4, " ") = " "
- * StringUtil.center("ab", -1, " ") = "ab"
- * StringUtil.center("ab", 4, " ") = " ab"
- * StringUtil.center("abcd", 2, " ") = "abcd"
- * StringUtil.center("a", 4, " ") = " a "
- * StringUtil.center("a", 4, "yz") = "yayz"
- * StringUtil.center("abc", 7, null) = " abc "
- * StringUtil.center("abc", 7, "") = " abc "
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 指定的长度
- * @param padStr
- * 长度不够时补充的字符串
- * @return String
- * @throws IllegalArgumentException
- * 如果被补充字符串为 null或者 empty
- */
- public static String center(String str, int size, String padStr) {
- if (str == null || size <= 0) {
- return str;
- }
- if (isEmpty(padStr)) {
- padStr = " ";
- }
- int strLen = str.length();
- int pads = size - strLen;
- if (pads <= 0) {
- return str;
- }
- str = leftPad(str, strLen + pads / 2, padStr);
- str = rightPad(str, size, padStr);
- return str;
- }
- /**
- * <p>
- * 检查字符串是否全部为小写.
- * </p>
- *
- * <pre>
- * StringUtil.isAllLowerCase(null) = false
- * StringUtil.isAllLowerCase("") = false
- * StringUtil.isAllLowerCase(" ") = false
- * StringUtil.isAllLowerCase("abc") = true
- * StringUtil.isAllLowerCase("abC") = false
- * </pre>
- *
- * @param cs
- * 源字符串
- * @return String
- */
- public static boolean isAllLowerCase(String cs) {
- if (cs == null || isEmpty(cs)) {
- return false;
- }
- int sz = cs.length();
- for (int i = 0; i < sz; i++) {
- if (Character.isLowerCase(cs.charAt(i)) == false) {
- return false;
- }
- }
- return true;
- }
- /**
- * <p>
- * 检查是否都是大写.
- * </p>
- *
- * <pre>
- * StringUtil.isAllUpperCase(null) = false
- * StringUtil.isAllUpperCase("") = false
- * StringUtil.isAllUpperCase(" ") = false
- * StringUtil.isAllUpperCase("ABC") = true
- * StringUtil.isAllUpperCase("aBC") = false
- * </pre>
- *
- * @param cs
- * 源字符串
- * @return String
- */
- public static boolean isAllUpperCase(String cs) {
- if (cs == null || StringUtil.isEmpty(cs)) {
- return false;
- }
- int sz = cs.length();
- for (int i = 0; i < sz; i++) {
- if (Character.isUpperCase(cs.charAt(i)) == false) {
- return false;
- }
- }
- return true;
- }
- /**
- * <p>
- * 反转字符串.
- * </p>
- *
- * <pre>
- * StringUtil.reverse(null) = null
- * StringUtil.reverse("") = ""
- * StringUtil.reverse("bat") = "tab"
- * </pre>
- *
- * @param str
- * 源字符串
- * @return String
- */
- public static String reverse(String str) {
- if (str == null) {
- return null;
- }
- return new StringBuilder(str).reverse().toString();
- }
- /**
- * <p>
- * 字符串达不到一定长度时在右边补空白.
- * </p>
- *
- * <pre>
- * StringUtil.rightPad(null, *) = null
- * StringUtil.rightPad("", 3) = " "
- * StringUtil.rightPad("bat", 3) = "bat"
- * StringUtil.rightPad("bat", 5) = "bat "
- * StringUtil.rightPad("bat", 1) = "bat"
- * StringUtil.rightPad("bat", -1) = "bat"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param size
- * 指定的长度
- * @return String
- */
- public static String rightPad(String str, int size) {
- return rightPad(str, size, ' ');
- }
- /**
- * 从右边截取字符串.</p>
- *
- * <pre>
- * StringUtil.right(null, *) = null
- * StringUtil.right(*, -ve) = ""
- * StringUtil.right("", *) = ""
- * StringUtil.right("abc", 0) = ""
- * StringUtil.right("abc", 2) = "bc"
- * StringUtil.right("abc", 4) = "abc"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param len
- * 长度
- * @return String
- */
- public static String right(String str, int len) {
- if (str == null) {
- return null;
- }
- if (len < 0) {
- return EMPTY;
- }
- if (str.length() <= len) {
- return str;
- }
- return str.substring(str.length() - len);
- }
- /**
- * <p>
- * 截取一个字符串的前几个.
- * </p>
- *
- * <pre>
- * StringUtil.left(null, *) = null
- * StringUtil.left(*, -ve) = ""
- * StringUtil.left("", *) = ""
- * StringUtil.left("abc", 0) = ""
- * StringUtil.left("abc", 2) = "ab"
- * StringUtil.left("abc", 4) = "abc"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param len
- * 截取的长度
- * @return the String
- */
- public static String left(String str, int len) {
- if (str == null) {
- return null;
- }
- if (len < 0) {
- return EMPTY;
- }
- if (str.length() <= len) {
- return str;
- }
- return str.substring(0, len);
- }
- /**
- * <p>
- * 得到tag字符串中间的子字符串,只返回第一个匹配项。
- * </p>
- *
- * <pre>
- * StringUtil.substringBetween(null, *) = null
- * StringUtil.substringBetween("", "") = ""
- * StringUtil.substringBetween("", "tag") = null
- * StringUtil.substringBetween("tagabctag", null) = null
- * StringUtil.substringBetween("tagabctag", "") = ""
- * StringUtil.substringBetween("tagabctag", "tag") = "abc"
- * </pre>
- *
- * @param str
- * 源字符串。
- * @param tag
- * 标识字符串。
- * @return String 子字符串, 如果没有符合要求的,返回{@code null}。
- */
- public static String substringBetween(String str, String tag) {
- return substringBetween(str, tag, tag);
- }
- /**
- * <p>
- * 得到两个字符串中间的子字符串,只返回第一个匹配项。
- * </p>
- *
- * <pre>
- * StringUtil.substringBetween("wx[b]yz", "[", "]") = "b"
- * StringUtil.substringBetween(null, *, *) = null
- * StringUtil.substringBetween(*, null, *) = null
- * StringUtil.substringBetween(*, *, null) = null
- * StringUtil.substringBetween("", "", "") = ""
- * StringUtil.substringBetween("", "", "]") = null
- * StringUtil.substringBetween("", "[", "]") = null
- * StringUtil.substringBetween("yabcz", "", "") = ""
- * StringUtil.substringBetween("yabcz", "y", "z") = "abc"
- * StringUtil.substringBetween("yabczyabcz", "y", "z") = "abc"
- * </pre>
- *
- * @param str
- * 源字符串
- * @param open
- * 起字符串。
- * @param close
- * 末字符串。
- * @return String 子字符串, 如果没有符合要求的,返回{@code null}。
- */
- public static String substringBetween(String str, String open, String close) {
- if (str == null || open == null || close == null) {
- return null;
- }
- int start = str.indexOf(open);
- if (start != INDEX_NOT_FOUND) {
- int end = str.indexOf(close, start + open.length());
- if (end != INDEX_NOT_FOUND) {
- return str.substring(start + open.length(), end);
- }
- }
- return null;
- }
- /**
- * <p>
- * 得到两个字符串中间的子字符串,所有匹配项组合为数组并返回。
- * </p>
- *
- * <pre>
- * StringUtil.substringsBetween("[a][b][c]", "[", "]") = ["a","b","c"]
- * StringUtil.substringsBetween(null, *, *) = null
- * StringUtil.substringsBetween(*, null, *) = null
- * StringUtil.substringsBetween(*, *, null) = null
- * StringUtil.substringsBetween("", "[", "]") = []
- * </pre>
- *
- * @param str
- * 源字符串
- * @param open
- * 起字符串。
- * @param close
- * 末字符串。
- * @return String 子字符串数组, 如果没有符合要求的,返回{@code null}。
- */
- public static String[] substringsBetween(String str, String open,
- String close) {
- if (str == null || isEmpty(open) || isEmpty(close)) {
- return null;
- }
- int strLen = str.length();
- if (strLen == 0) {
- return new String[0];
- }
- int closeLen = close.length();
- int openLen = open.length();
- List<String> list = new ArrayList<String>();
- int pos = 0;
- while (pos < strLen - closeLen) {
- int start = str.indexOf(open, pos);
- if (start < 0) {
- break;
- }
- start += openLen;
- int end = str.indexOf(close, start);
- if (end < 0) {
- break;
- }
- list.add(str.substring(start, end));
- pos = end + closeLen;
- }
- if (list.isEmpty()) {
- return null;
- }
- return list.toArray(new String[list.size()]);
- }
- /**
- * 功能:切换字符串中的所有字母大小写。<br/>
- *
- * <pre>
- * StringUtil.swapCase(null) = null
- * StringUtil.swapCase("") = ""
- * StringUtil.swapCase("The dog has a BONE") = "tHE DOG HAS A bone"
- * </pre>
- *
- *
- * @param str
- * 源字符串
- * @return String
- */
- public static String swapCase(String str) {
- if (StringUtil.isEmpty(str)) {
- return str;
- }
- char[] buffer = str.toCharArray();
- boolean whitespace = true;
- for (int i = 0; i < buffer.length; i++) {
- char ch = buffer[i];
- if (Character.isUpperCase(ch)) {
- buffer[i] = Character.toLowerCase(ch);
- whitespace = false;
- } else if (Character.isTitleCase(ch)) {
- buffer[i] = Character.toLowerCase(ch);
- whitespace = false;
- } else if (Character.isLowerCase(ch)) {
- if (whitespace) {
- buffer[i] = Character.toTitleCase(ch);
- whitespace = false;
- } else {
- buffer[i] = Character.toUpperCase(ch);
- }
- } else {
- whitespace = Character.isWhitespace(ch);
- }
- }
- return new String(buffer);
- }
- /**
- * 功能:截取出最后一个标志位之后的字符串.<br/>
- * 如果sourceStr为empty或者expr为null,直接返回源字符串。<br/>
- * 如果expr长度为0,直接返回sourceStr。<br/>
- * 如果expr在sourceStr中不存在,直接返回sourceStr。<br/>
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param sourceStr
- * 被截取的字符串
- * @param expr
- * 分隔符
- * @return String
- */
- public static String substringAfterLast(String sourceStr, String expr) {
- if (isEmpty(sourceStr) || expr == null) {
- return sourceStr;
- }
- if (expr.length() == 0) {
- return sourceStr;
- }
- int pos = sourceStr.lastIndexOf(expr);
- if (pos == -1) {
- return sourceStr;
- }
- return sourceStr.substring(pos + expr.length());
- }
- /**
- * 功能:截取出最后一个标志位之前的字符串.<br/>
- * 如果sourceStr为empty或者expr为null,直接返回源字符串。<br/>
- * 如果expr长度为0,直接返回sourceStr。<br/>
- * 如果expr在sourceStr中不存在,直接返回sourceStr。<br/>
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param sourceStr
- * 被截取的字符串
- * @param expr
- * 分隔符
- * @return String
- */
- public static String substringBeforeLast(String sourceStr, String expr) {
- if (isEmpty(sourceStr) || expr == null) {
- return sourceStr;
- }
- if (expr.length() == 0) {
- return sourceStr;
- }
- int pos = sourceStr.lastIndexOf(expr);
- if (pos == -1) {
- return sourceStr;
- }
- return sourceStr.substring(0, pos);
- }
- /**
- * 功能:截取出第一个标志位之后的字符串.<br/>
- * 如果sourceStr为empty或者expr为null,直接返回源字符串。<br/>
- * 如果expr长度为0,直接返回sourceStr。<br/>
- * 如果expr在sourceStr中不存在,直接返回sourceStr。<br/>
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param sourceStr
- * 被截取的字符串
- * @param expr
- * 分隔符
- * @return String
- */
- public static String substringAfter(String sourceStr, String expr) {
- if (isEmpty(sourceStr) || expr == null) {
- return sourceStr;
- }
- if (expr.length() == 0) {
- return sourceStr;
- }
- int pos = sourceStr.indexOf(expr);
- if (pos == -1) {
- return sourceStr;
- }
- return sourceStr.substring(pos + expr.length());
- }
- /**
- * 功能:截取出第一个标志位之前的字符串.<br/>
- * 如果sourceStr为empty或者expr为null,直接返回源字符串。<br/>
- * 如果expr长度为0,直接返回sourceStr。<br/>
- * 如果expr在sourceStr中不存在,直接返回sourceStr。<br/>
- * 如果expr在sourceStr中存在不止一个,以第一个位置为准。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param sourceStr
- * 被截取的字符串
- * @param expr
- * 分隔符
- * @return String
- */
- public static String substringBefore(String sourceStr, String expr) {
- if (isEmpty(sourceStr) || expr == null) {
- return sourceStr;
- }
- if (expr.length() == 0) {
- return sourceStr;
- }
- int pos = sourceStr.indexOf(expr);
- if (pos == -1) {
- return sourceStr;
- }
- return sourceStr.substring(0, pos);
- }
- /**
- * 功能:检查这个字符串是不是空字符串。<br/>
- * 如果这个字符串为null或者trim后为空字符串则返回true,否则返回false。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param chkStr
- * 被检查的字符串
- * @return boolean
- */
- public static boolean isEmpty(String chkStr) {
- if (chkStr == null) {
- return true;
- } else {
- return "".equals(chkStr.trim()) ? true : false;
- }
- }
- /**
- * 如果字符串没有超过最长显示长度返回原字符串,否则从开头截取指定长度并加...返回。
- *
- * @param str
- * 原字符串
- * @param length
- * 字符串最长显示的长度
- * @return 转换后的字符串
- */
- public static String trimString(String str, int length) {
- if (str == null) {
- return "";
- } else if (str.length() > length) {
- return str.substring(0, length - 3) + "...";
- } else {
- return str;
- }
- }
- }
二、MD5
- package com.mkyong.common;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.nio.MappedByteBuffer;
- import java.nio.channels.FileChannel;
- import java.security.MessageDigest;
- import java.security.NoSuchAlgorithmException;
- /**
- *
- * String工具类. <br>
- *
- * @author 宋立君
- * @date 2014年06月24日
- */
- public class MD5Util {
- protected static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6',
- '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
- protected static MessageDigest messagedigest = null;
- static {
- try {
- messagedigest = MessageDigest.getInstance("MD5");
- } catch (NoSuchAlgorithmException nsaex) {
- System.err.println(MD5Util.class.getName()
- + "初始化失败,MessageDigest不支持MD5Util。");
- nsaex.printStackTrace();
- }
- }
- /**
- * 功能:加盐版的MD5.返回格式为MD5(密码+{盐值})
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param password
- * 密码
- * @param salt
- * 盐值
- * @return String
- */
- public static String getMD5StringWithSalt(String password, String salt) {
- if (password == null) {
- throw new IllegalArgumentException("password不能为null");
- }
- if (StringUtil.isEmpty(salt)) {
- throw new IllegalArgumentException("salt不能为空");
- }
- if ((salt.toString().lastIndexOf("{") != -1)
- || (salt.toString().lastIndexOf("}") != -1)) {
- throw new IllegalArgumentException("salt中不能包含 { 或者 }");
- }
- return getMD5String(password + "{" + salt.toString() + "}");
- }
- /**
- * 功能:得到文件的md5值。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param file
- * 文件。
- * @return String
- * @throws IOException
- * 读取文件IO异常时。
- */
- public static String getFileMD5String(File file) throws IOException {
- FileInputStream in = new FileInputStream(file);
- FileChannel ch = in.getChannel();
- MappedByteBuffer byteBuffer = ch.map(FileChannel.MapMode.READ_ONLY, 0,
- file.length());
- messagedigest.update(byteBuffer);
- return bufferToHex(messagedigest.digest());
- }
- /**
- * 功能:得到一个字符串的MD5值。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param str
- * 字符串
- * @return String
- */
- public static String getMD5String(String str) {
- return getMD5String(str.getBytes());
- }
- private static String getMD5String(byte[] bytes) {
- messagedigest.update(bytes);
- return bufferToHex(messagedigest.digest());
- }
- private static String bufferToHex(byte bytes[]) {
- return bufferToHex(bytes, 0, bytes.length);
- }
- private static String bufferToHex(byte bytes[], int m, int n) {
- StringBuffer stringbuffer = new StringBuffer(2 * n);
- int k = m + n;
- for (int l = m; l < k; l++) {
- appendHexPair(bytes[l], stringbuffer);
- }
- return stringbuffer.toString();
- }
- private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
- char c0 = hexDigits[(bt & 0xf0) >> 4];
- char c1 = hexDigits[bt & 0xf];
- stringbuffer.append(c0);
- stringbuffer.append(c1);
- }
- }
三、File工具类
- package com.mkyong.common;
- import java.io.ByteArrayInputStream;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStream;
- /**
- * 文件相关操作辅助类。
- *
- * @author 宋立君
- * @date 2014年06月24日
- */
- public class FileUtil {
- private static final String FOLDER_SEPARATOR = "/";
- private static final char EXTENSION_SEPARATOR = '.';
- /**
- * 功能:复制文件或者文件夹。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param inputFile
- * 源文件
- * @param outputFile
- * 目的文件
- * @param isOverWrite
- * 是否覆盖(只针对文件)
- * @throws IOException
- */
- public static void copy(File inputFile, File outputFile, boolean isOverWrite)
- throws IOException {
- if (!inputFile.exists()) {
- throw new RuntimeException(inputFile.getPath() + "源目录不存在!");
- }
- copyPri(inputFile, outputFile, isOverWrite);
- }
- /**
- * 功能:为copy 做递归使用。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param inputFile
- * @param outputFile
- * @param isOverWrite
- * @throws IOException
- */
- private static void copyPri(File inputFile, File outputFile,
- boolean isOverWrite) throws IOException {
- // 是个文件。
- if (inputFile.isFile()) {
- copySimpleFile(inputFile, outputFile, isOverWrite);
- } else {
- // 文件夹
- if (!outputFile.exists()) {
- outputFile.mkdir();
- }
- // 循环子文件夹
- for (File child : inputFile.listFiles()) {
- copy(child,
- new File(outputFile.getPath() + "/" + child.getName()),
- isOverWrite);
- }
- }
- }
- /**
- * 功能:copy单个文件
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param inputFile
- * 源文件
- * @param outputFile
- * 目标文件
- * @param isOverWrite
- * 是否允许覆盖
- * @throws IOException
- */
- private static void copySimpleFile(File inputFile, File outputFile,
- boolean isOverWrite) throws IOException {
- // 目标文件已经存在
- if (outputFile.exists()) {
- if (isOverWrite) {
- if (!outputFile.delete()) {
- throw new RuntimeException(outputFile.getPath() + "无法覆盖!");
- }
- } else {
- // 不允许覆盖
- return;
- }
- }
- InputStream in = new FileInputStream(inputFile);
- OutputStream out = new FileOutputStream(outputFile);
- byte[] buffer = new byte[1024];
- int read = 0;
- while ((read = in.read(buffer)) != -1) {
- out.write(buffer, 0, read);
- }
- in.close();
- out.close();
- }
- /**
- * 功能:删除文件
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param file
- * 文件
- */
- public static void delete(File file) {
- deleteFile(file);
- }
- /**
- * 功能:删除文件,内部递归使用
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param file
- * 文件
- * @return boolean true 删除成功,false 删除失败。
- */
- private static void deleteFile(File file) {
- if (file == null || !file.exists()) {
- return;
- }
- // 单文件
- if (!file.isDirectory()) {
- boolean delFlag = file.delete();
- if (!delFlag) {
- throw new RuntimeException(file.getPath() + "删除失败!");
- } else {
- return;
- }
- }
- // 删除子目录
- for (File child : file.listFiles()) {
- deleteFile(child);
- }
- // 删除自己
- file.delete();
- }
- /**
- * 从文件路径中抽取文件的扩展名, 例如. "mypath/myfile.txt" -> "txt". * @author 宋立君
- *
- * @date 2014年06月24日
- * @param 文件路径
- * @return 如果path为null,直接返回null。
- */
- public static String getFilenameExtension(String path) {
- if (path == null) {
- return null;
- }
- int extIndex = path.lastIndexOf(EXTENSION_SEPARATOR);
- if (extIndex == -1) {
- return null;
- }
- int folderIndex = path.lastIndexOf(FOLDER_SEPARATOR);
- if (folderIndex > extIndex) {
- return null;
- }
- return path.substring(extIndex + 1);
- }
- /**
- * 从文件路径中抽取文件名, 例如: "mypath/myfile.txt" -> "myfile.txt"。 * @author 宋立君
- *
- * @date 2014年06月24日
- * @param path
- * 文件路径。
- * @return 抽取出来的文件名, 如果path为null,直接返回null。
- */
- public static String getFilename(String path) {
- if (path == null) {
- return null;
- }
- int separatorIndex = path.lastIndexOf(FOLDER_SEPARATOR);
- return (separatorIndex != -1 ? path.substring(separatorIndex + 1)
- : path);
- }
- /**
- * 功能:保存文件。
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param content
- * 字节
- * @param file
- * 保存到的文件
- * @throws IOException
- */
- public static void save(byte[] content, File file) throws IOException {
- if (file == null) {
- throw new RuntimeException("保存文件不能为空");
- }
- if (content == null) {
- throw new RuntimeException("文件流不能为空");
- }
- InputStream is = new ByteArrayInputStream(content);
- save(is, file);
- }
- /**
- * 功能:保存文件
- *
- * @author 宋立君
- * @date 2014年06月24日
- * @param streamIn
- * 文件流
- * @param file
- * 保存到的文件
- * @throws IOException
- */
- public static void save(InputStream streamIn, File file) throws IOException {
- if (file == null) {
- throw new RuntimeException("保存文件不能为空");
- }
- if (streamIn == null) {
- throw new RuntimeException("文件流不能为空");
- }
- // 输出流
- OutputStream streamOut = null;
- // 文件夹不存在就创建。
- if (!file.getParentFile().exists()) {
- file.getParentFile().mkdirs();
- }
- streamOut = new FileOutputStream(file);
- int bytesRead = 0;
- byte[] buffer = new byte[8192];
- while ((bytesRead = streamIn.read(buffer, 0, 8192)) != -1) {
- streamOut.write(buffer, 0, bytesRead);
- }
- streamOut.close();
- streamIn.close();
- }
- }
1、FtpUtil
- package com.itjh.javaUtil;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.OutputStream;
- import java.util.ArrayList;
- import java.util.List;
- import org.apache.commons.net.ftp.FTPClient;
- import org.apache.commons.net.ftp.FTPFile;
- import org.apache.commons.net.ftp.FTPReply;
- /**
- * 用来操作ftp的综合类。<br/>
- * 主要依赖jar包commons-net-3.1.jar。
- *
- * @author 宋立君
- * @date 2014年06月25日
- */
- public class FtpUtil {
- // ftp 地址
- private String url;
- // ftp端口
- private int port;
- // 用户名
- private String userName;
- // 密码
- private String password;
- /**
- * 构造函数
- *
- * @param url
- * ftp地址
- * @param port
- * ftp端口
- * @param userName
- * 用户名
- * @param password
- * 密码
- * @author 宋立君
- * @date 2014年06月25日
- *
- */
- public FtpUtil(String url, int port, String userName, String password) {
- this.url = url;
- this.port = port;
- this.userName = userName;
- this.password = password;
- }
- /**
- * 从FTP服务器下载指定文件名的文件。
- *
- * @param remotePath
- * FTP服务器上的相对路径
- * @param fileName
- * 要下载的文件名
- * @param localPath
- * 下载后保存到本地的路径
- * @return 成功下载返回true,否则返回false。
- * @throws IOException
- * @author 宋立君
- * @date 2014年06月25日
- */
- public boolean downFile(String remotePath, String fileName, String localPath)
- throws IOException {
- boolean success = false;
- FTPClient ftp = new FTPClient();
- try {
- int reply;
- ftp.connect(url, port);
- // 如果采用默认端口,可以使用ftp.connect(url)的方式直接连接FTP服务器
- ftp.login(userName, password);// 登录
- reply = ftp.getReplyCode();
- if (!FTPReply.isPositiveCompletion(reply)) {
- ftp.disconnect();
- return success;
- }
- ftp.changeWorkingDirectory(remotePath);// 转移到FTP服务器目录
- FTPFile[] fs = ftp.listFiles();
- FTPFile ff;
- for (int i = 0; i < fs.length; i++) {
- ff = fs[i];
- if (null != ff && null != ff.getName()
- && ff.getName().equals(fileName)) {
- File localFile = new File(localPath + "/" + ff.getName());
- OutputStream is = new FileOutputStream(localFile);
- ftp.retrieveFile(ff.getName(), is);
- is.close();
- }
- }
- ftp.logout();
- success = true;
- } catch (IOException e) {
- e.printStackTrace();
- throw e;
- } finally {
- if (ftp.isConnected()) {
- try {
- ftp.disconnect();
- } catch (IOException ioe) {
- }
- }
- }
- return success;
- }
- /**
- * 从FTP服务器列出指定文件夹下文件名列表。
- *
- * @param remotePath
- * FTP服务器上的相对路径
- * @return List<String> 文件名列表,如果出现异常返回null。
- * @throws IOException
- * @author 宋立君
- * @date 2014年06月25日
- */
- public List<String> getFileNameList(String remotePath) throws IOException {
- // 目录列表记录
- List<String> fileNames = new ArrayList<String>();
- FTPClient ftp = new FTPClient();
- try {
- int reply;
- ftp.connect(url, port);
- // 如果采用默认端口,可以使用ftp.connect(url)的方式直接连接FTP服务器
- ftp.login(userName, password);// 登录
- reply = ftp.getReplyCode();
- if (!FTPReply.isPositiveCompletion(reply)) {
- ftp.disconnect();
- return null;
- }
- ftp.changeWorkingDirectory(remotePath);// 转移到FTP服务器目录
- FTPFile[] fs = ftp.listFiles();
- for (FTPFile file : fs) {
- fileNames.add(file.getName());
- }
- ftp.logout();
- } catch (IOException e) {
- e.printStackTrace();
- throw e;
- } finally {
- if (ftp.isConnected()) {
- try {
- ftp.disconnect();
- } catch (IOException ioe) {
- }
- }
- }
- return fileNames;
- }
- }
2、 汉字转拼音
- package com.itjh.test;
- import net.sourceforge.pinyin4j.PinyinHelper;
- import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType;
- import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat;
- import net.sourceforge.pinyin4j.format.HanyuPinyinToneType;
- import net.sourceforge.pinyin4j.format.HanyuPinyinVCharType;
- public class SpellHelper {
- //将中文转换为英文
- public static String getEname(String name) {
- HanyuPinyinOutputFormat pyFormat = new HanyuPinyinOutputFormat();
- pyFormat.setCaseType(HanyuPinyinCaseType. LOWERCASE);
- pyFormat.setToneType(HanyuPinyinToneType. WITHOUT_TONE);
- pyFormat.setVCharType(HanyuPinyinVCharType. WITH_V);
- return PinyinHelper. toHanyuPinyinString(name, pyFormat, "");
- }
- //姓、名的第一个字母需要为大写
- public static String getUpEname(String name) {
- char[] strs = name.toCharArray();
- String newname = null;
- //名字的长度
- if (strs.length == 2) {
- newname = toUpCase(getEname ("" + strs[0])) + " "
- + toUpCase(getEname ("" + strs[1]));
- } else if (strs. length == 3) {
- newname = toUpCase(getEname ("" + strs[0])) + " "
- + toUpCase(getEname ("" + strs[1] + strs[2]));
- } else if (strs. length == 4) {
- newname = toUpCase(getEname ("" + strs[0] + strs[1])) + " "
- + toUpCase(getEname ("" + strs[2] + strs[3]));
- } else {
- newname = toUpCase(getEname (name));
- }
- return newname;
- }
- //首字母大写
- private static String toUpCase(String str) {
- StringBuffer newstr = new StringBuffer();
- newstr.append((str.substring(0, 1)).toUpperCase()).append(
- str.substring(1, str.length()));
- return newstr.toString();
- }
- public static void main(String[] args) {
- System. out.println( getEname("李宇春"));
- }
- }
3、zip工具类
- package com.itjh.javaUtil;
- import java.io.BufferedInputStream;
- import java.io.BufferedOutputStream;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.util.Enumeration;
- import org.apache.commons.compress.archivers.zip.Zip64Mode;
- import org.apache.commons.compress.archivers.zip.ZipArchiveEntry;
- import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream;
- import org.apache.commons.compress.archivers.zip.ZipFile;
- import org.apache.commons.compress.utils.IOUtils;
- /**
- * Zip工具栏类,依赖于commons-compress-1.5.jar。
- *
- * @author 宋立君
- * @date 2014年06月25日
- */
- public class ZipUtil {
- // public static void main(String[] args){
- // try {
- // //new ZipUtil().decompressZip(new
- // File("d://img.zip"),"img/pic20140626.jpg","d://");
- // new ZipUtil().decompressZip(new File("d://img.zip"),"flight.log","d://");
- // //new File("d://flight.log").delete();
- // //ZipUtil.compress(new File("D://测试压缩文件"),new File("d://img.zip"));
- // // ZipUtil.compress(new File[]{new
- // File("F:/testZIP/testzip.txt"),new File("d://ftp"),new
- // File("e://ftp")},new File("d://压缩文件.zip"));
- // } catch (IOException e) {
- // e.printStackTrace();
- // }
- // }
- /**
- * 把N多文件或文件夹压缩成zip。
- *
- * @param files
- * 需要压缩的文件或文件夹。
- * @param zipFilePath
- * 压缩后的zip文件
- * @throws IOException
- * 压缩时IO异常。
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static void compress(File[] files, File zipFile) throws IOException {
- if (CollectionUtil.isEmpty(files)) {
- return;
- }
- ZipArchiveOutputStream out = new ZipArchiveOutputStream(zipFile);
- out.setUseZip64(Zip64Mode.AsNeeded);
- // 将每个文件用ZipArchiveEntry封装
- for (File file : files) {
- if (file == null) {
- continue;
- }
- compressOneFile(file, out, "");
- }
- if (out != null) {
- out.close();
- }
- }
- /**
- * 功能:压缩文件或文件夹。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param srcFile
- * 源文件。
- * @param destFile
- * 压缩后的文件
- * @throws IOException
- * 压缩时出现了异常。
- */
- public static void compress(File srcFile, File destFile) throws IOException {
- ZipArchiveOutputStream out = null;
- try {
- out = new ZipArchiveOutputStream(new BufferedOutputStream(
- new FileOutputStream(destFile), 1024));
- compressOneFile(srcFile, out, "");
- } finally {
- out.close();
- }
- }
- /**
- * 功能:压缩单个文件,非文件夹。私有,不对外开放。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param srcFile
- * 源文件,不能是文件夹。
- * @param out
- * 压缩文件的输出流。
- * @param destFile
- * 压缩后的文件
- * @param dir
- * 在压缩包中的位置,根目录传入/。
- * @throws IOException
- * 压缩时出现了异常。
- */
- private static void compressOneFile(File srcFile,
- ZipArchiveOutputStream out, String dir) throws IOException {
- if (srcFile.isDirectory()) {// 对文件夹进行处理。
- ZipArchiveEntry entry = new ZipArchiveEntry(dir + srcFile.getName()
- + "/");
- out.putArchiveEntry(entry);
- out.closeArchiveEntry();
- // 循环文件夹中的所有文件进行压缩处理。
- String[] subFiles = srcFile.list();
- for (String subFile : subFiles) {
- compressOneFile(new File(srcFile.getPath() + "/" + subFile),
- out, (dir + srcFile.getName() + "/"));
- }
- } else { // 普通文件。
- InputStream is = null;
- try {
- is = new BufferedInputStream(new FileInputStream(srcFile));
- // 创建一个压缩包。
- ZipArchiveEntry entry = new ZipArchiveEntry(srcFile, dir
- + srcFile.getName());
- out.putArchiveEntry(entry);
- IOUtils.copy(is, out);
- out.closeArchiveEntry();
- } finally {
- if (is != null)
- is.close();
- }
- }
- }
- /**
- * 功能:解压缩zip压缩包下的所有文件。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param zipFile
- * zip压缩文件
- * @param dir
- * 解压缩到这个路径下
- * @throws IOException
- * 文件流异常
- */
- public void decompressZip(File zipFile, String dir) throws IOException {
- ZipFile zf = new ZipFile(zipFile);
- try {
- for (Enumeration<ZipArchiveEntry> entries = zf.getEntries(); entries
- .hasMoreElements();) {
- ZipArchiveEntry ze = entries.nextElement();
- // 不存在则创建目标文件夹。
- File targetFile = new File(dir, ze.getName());
- // 遇到根目录时跳过。
- if (ze.getName().lastIndexOf("/") == (ze.getName().length() - 1)) {
- continue;
- }
- // 如果文件夹不存在,创建文件夹。
- if (!targetFile.getParentFile().exists()) {
- targetFile.getParentFile().mkdirs();
- }
- InputStream i = zf.getInputStream(ze);
- OutputStream o = null;
- try {
- o = new FileOutputStream(targetFile);
- IOUtils.copy(i, o);
- } finally {
- if (i != null) {
- i.close();
- }
- if (o != null) {
- o.close();
- }
- }
- }
- } finally {
- zf.close();
- }
- }
- /**
- * 功能:解压缩zip压缩包下的某个文件信息。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param zipFile
- * zip压缩文件
- * @param fileName
- * 某个文件名,例如abc.zip下面的a.jpg,需要传入/abc/a.jpg。
- * @param dir
- * 解压缩到这个路径下
- * @throws IOException
- * 文件流异常
- */
- public void decompressZip(File zipFile, String fileName, String dir)
- throws IOException {
- // 不存在则创建目标文件夹。
- File targetFile = new File(dir, fileName);
- if (!targetFile.getParentFile().exists()) {
- targetFile.getParentFile().mkdirs();
- }
- ZipFile zf = new ZipFile(zipFile);
- Enumeration<ZipArchiveEntry> zips = zf.getEntries();
- ZipArchiveEntry zip = null;
- while (zips.hasMoreElements()) {
- zip = zips.nextElement();
- if (fileName.equals(zip.getName())) {
- OutputStream o = null;
- InputStream i = zf.getInputStream(zip);
- try {
- o = new FileOutputStream(targetFile);
- IOUtils.copy(i, o);
- } finally {
- if (i != null) {
- i.close();
- }
- if (o != null) {
- o.close();
- }
- }
- }
- }
- }
- /**
- * 功能:得到zip压缩包下的某个文件信息,只能在根目录下查找。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param zipFile
- * zip压缩文件
- * @param fileName
- * 某个文件名,例如abc.zip下面的a.jpg,需要传入/abc/a.jpg。
- * @return ZipArchiveEntry 压缩文件中的这个文件,没有找到返回null。
- * @throws IOException
- * 文件流异常
- */
- public ZipArchiveEntry readZip(File zipFile, String fileName)
- throws IOException {
- ZipFile zf = new ZipFile(zipFile);
- Enumeration<ZipArchiveEntry> zips = zf.getEntries();
- ZipArchiveEntry zip = null;
- while (zips.hasMoreElements()) {
- zip = zips.nextElement();
- if (fileName.equals(zip.getName())) {
- return zip;
- }
- }
- return null;
- }
- /**
- * 功能:得到zip压缩包下的所有文件信息。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param zipFile
- * zip压缩文件
- * @return Enumeration<ZipArchiveEntry> 压缩文件中的文件枚举。
- * @throws IOException
- * 文件流异常
- */
- public Enumeration<ZipArchiveEntry> readZip(File zipFile)
- throws IOException {
- ZipFile zf = new ZipFile(zipFile);
- Enumeration<ZipArchiveEntry> zips = zf.getEntries();
- return zips;
- }
- }
4 CollectionUtil代码:
- package com.itjh.javaUtil;
- import java.util.Collection;
- import java.util.LinkedList;
- import java.util.List;
- import java.util.Map;
- /**
- * 集合(List,Map,Set)辅助类。
- * @author 宋立君
- * @date 2014年06月25日
- */
- public class CollectionUtil {
- /**
- * 功能:从List中随机取出一个元素。
- * @author 宋立君
- * @date 2014年06月25日
- * @param objs 源List
- * @return T List的一个元素
- */
- public static <T> T randomOne(List<T> list){
- if(isEmpty(list)){
- return null;
- }
- return list.get(MathUtil.randomNumber(0, list.size()));
- }
- /**
- * 功能:从数组中随机取出一个元素。
- * @author 宋立君
- * @date 2014年06月25日
- * @param objs 源数组
- * @return T 数组的一个元素
- */
- public static <T> T randomOne(T[] objs){
- if(isEmpty(objs)){
- return null;
- }
- return objs[MathUtil.randomNumber(0, objs.length)];
- }
- /**
- * 功能:数组中是否存在这个元素。
- * @author 宋立君
- * @date 2014年06月25日
- * @param objArr 数组
- * @param compare 元素
- * @return 存在返回true,否则返回false。
- */
- public static <T> boolean arrayContain(T[] objArr,T compare){
- if(isEmpty(objArr)){
- return false;
- }
- for(T obj : objArr){
- if(obj.equals(compare)){
- return true;
- }
- }
- return false;
- }
- /**
- * 功能:向list中添加数组。
- * @author 宋立君
- * @date 2014年06月25日
- * @param list List
- * @param array 数组
- */
- public static <T> void addArrayToList(List<T> list, T[] array) {
- if (isEmpty(list)) {
- return;
- }
- for (T t : array) {
- list.add(t);
- }
- }
- /**
- * 功能:将数组进行反转,倒置。
- * @author 宋立君
- * @date 2014年06月25日
- * @param objs 源数组
- * @return T[] 反转后的数组
- */
- public static <T> T[] reverseArray(T[] objs){
- if(isEmpty(objs)){
- return null;
- }
- T[] res=(T[])java.lang.reflect.Array.newInstance(objs[0].getClass(), objs.length);
- //新序号
- int k=0;
- for(int i=objs.length-1 ; i>=0 ; i--){
- res[k++]=objs[i];
- }
- return res;
- }
- /**
- * 功能:将数组转为list。
- * @author 宋立君
- * @date 2014年06月25日
- * @param objs 源数组
- * @return List
- */
- public static <T> List<T> arrayToList(T[] objs){
- if(isEmpty(objs)){
- return null;
- }
- List<T> list=new LinkedList<T>();
- for(T obj : objs){
- list.add(obj);
- }
- return list;
- }
- /**
- * 功能:将list转为数组。
- * @author 宋立君
- * @date 2014年06月25日
- * @param list 源list
- * @return T[]
- */
- public static <T> T[] listToArray(List<T> list){
- if(isEmpty(list)){
- return null;
- }
- T[] objs=(T[])java.lang.reflect.Array.newInstance(list.get(0).getClass(), list.size());
- int i=0; //数组下标。
- for(T obj : list){
- objs[i++]=obj;
- }
- return objs;
- }
- /**
- * 将一个字符串数组的内容全部添加到另外一个数组中,并返回一个新数组。
- * @param array1 第一个数组
- * @param array2 第二个数组
- * @return T[] 拼接后的新数组
- */
- public static <T> T[] concatenateArrays(T[] array1, T[] array2) {
- if (isEmpty(array1)) {
- return array2;
- }
- if (isEmpty(array2)) {
- return array1;
- }
- T[] resArray=(T[])java.lang.reflect.Array.newInstance(array1[0].getClass(), array1.length+array2.length);
- System.arraycopy(array1, 0, resArray, 0, array1.length);
- System.arraycopy(array2, 0, resArray, array1.length, array2.length);
- return resArray;
- }
- /**
- * 将一个object添加到一个数组中,并返回一个新数组。
- * @param array被添加到的数组
- * @param object 被添加的object
- * @return T[] 返回的新数组
- */
- public static <T> T[] addObjectToArray(T[] array, T obj) {
- //结果数组
- T[] resArray=null;
- if (isEmpty(array)) {
- resArray=(T[])java.lang.reflect.Array.newInstance(obj.getClass(), 1);
- resArray[0]=obj;
- return resArray;
- }
- //原数组不为空时。
- resArray=(T[])java.lang.reflect.Array.newInstance(array[0].getClass(), array.length+1);
- System.arraycopy(array, 0, resArray, 0, array.length);
- resArray[array.length] = obj;
- return resArray;
- }
- /**
- * 功能:判断数组是不是空。(null或者length==0)
- * @author 宋立君
- * @date 2014年06月25日
- * @param array 数组
- * @return boolean 空返回true,否则返回false。
- */
- public static <T> boolean isEmpty(T[] array) {
- return (array == null || array.length==0);
- }
- /**
- * 功能:集合是否为空。如果传入的值为null或者集合不包含元素都认为为空。
- * @author 宋立君
- * @date 2014年06月25日
- * @param collection 集合
- * @return boolean 为空返回true,否则返回false。
- */
- public static boolean isEmpty(Collection collection) {
- return (collection == null || collection.isEmpty());
- }
- /**
- * 功能:Map是否为空。如果传入的值为null或者集合不包含元素都认为为空。
- * @author 宋立君
- * @date 2014年06月25日
- * @param map Map
- * @return boolean 为空返回true,否则返回false。
- */
- public static boolean isEmpty(Map map) {
- return (map == null || map.isEmpty());
- }
- }
5 MathUtil代码:
- package com.itjh.javaUtil;
- import java.math.BigDecimal;
- /**
- * 数学运算辅助类。
- *
- * @author 宋立君
- * @date 2014年06月25日
- */
- public class MathUtil {
- /**
- * 功能:将字符串转换为BigDecimal,一般用于数字运算时。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param str
- * 字符串
- * @return BigDecimal,str为empty时返回null。
- */
- public static BigDecimal toBigDecimal(String str) {
- if (StringUtil.isEmpty(str)) {
- return null;
- }
- return new BigDecimal(str);
- }
- /**
- * 功能:将字符串抓换为double,如果失败返回默认值。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param str
- * 字符串
- * @param defaultValue
- * 失败时返回的默认值
- * @return double
- */
- public static double toDouble(String str, double defaultValue) {
- if (str == null) {
- return defaultValue;
- }
- try {
- return Double.parseDouble(str);
- } catch (NumberFormatException nfe) {
- return defaultValue;
- }
- }
- /**
- * 功能:将字符串抓换为float,如果失败返回默认值。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param str
- * 字符串
- * @param defaultValue
- * 失败时返回的默认值
- * @return float
- */
- public static float toFloat(String str, float defaultValue) {
- if (str == null) {
- return defaultValue;
- }
- try {
- return Float.parseFloat(str);
- } catch (NumberFormatException nfe) {
- return defaultValue;
- }
- }
- /**
- * 功能:将字符串抓换为long,如果失败返回默认值。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param str
- * 字符串
- * @param defaultValue
- * 失败时返回的默认值
- * @return long
- */
- public static long toLong(String str, long defaultValue) {
- if (str == null) {
- return defaultValue;
- }
- try {
- return Long.parseLong(str);
- } catch (NumberFormatException nfe) {
- return defaultValue;
- }
- }
- /**
- * 功能:将字符串抓换为int,如果失败返回默认值。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param str
- * 字符串
- * @param defaultValue
- * 失败时返回的默认值
- * @return int
- */
- public static int toInt(String str, int defaultValue) {
- if (str == null) {
- return defaultValue;
- }
- try {
- return Integer.parseInt(str);
- } catch (NumberFormatException nfe) {
- return defaultValue;
- }
- }
- /**
- * <p>
- * 得到两个 <code>double</code>值中最大的一个.
- * </p>
- *
- * @param a
- * 值 1
- * @param b
- * 值 2
- * @return 最大的值
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static float getMax(float a, float b) {
- if (Float.isNaN(a)) {
- return b;
- } else if (Float.isNaN(b)) {
- return a;
- } else {
- return Math.max(a, b);
- }
- }
- /**
- * <p>
- * 得到数组中最大的一个.
- * </p>
- *
- * @param array
- * 数组不能为null,也不能为空。
- * @return 得到数组中最大的一个.
- * @throws IllegalArgumentException
- * 如果 <code>数组</code> 是 <code>null</code>
- * @throws IllegalArgumentException
- * 如果 <code>数组</code>是空
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static float getMax(float[] array) {
- // Validates input
- if (array == null) {
- throw new IllegalArgumentException("The Array must not be null");
- } else if (array.length == 0) {
- throw new IllegalArgumentException("Array cannot be empty.");
- }
- // Finds and returns max
- float max = array[0];
- for (int j = 1; j < array.length; j++) {
- max = getMax(array[j], max);
- }
- return max;
- }
- /**
- * <p>
- * 得到数组中最大的一个.
- * </p>
- *
- * @param array
- * 数组不能为null,也不能为空。
- * @return 得到数组中最大的一个.
- * @throws IllegalArgumentException
- * 如果 <code>数组</code> 是 <code>null</code>
- * @throws IllegalArgumentException
- * 如果 <code>数组</code>是空
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double getMax(double[] array) {
- // Validates input
- if (array == null) {
- throw new IllegalArgumentException("The Array must not be null");
- } else if (array.length == 0) {
- throw new IllegalArgumentException("Array cannot be empty.");
- }
- // Finds and returns max
- double max = array[0];
- for (int j = 1; j < array.length; j++) {
- max = getMax(array[j], max);
- }
- return max;
- }
- /**
- * <p>
- * 得到两个 <code>double</code>值中最大的一个.
- * </p>
- *
- * @param a
- * 值 1
- * @param b
- * 值 2
- * @return 最大的值
- * @author 宋立君
- * @date 2014年06月25日
- * */
- public static double getMax(double a, double b) {
- if (Double.isNaN(a)) {
- return b;
- } else if (Double.isNaN(b)) {
- return a;
- } else {
- return Math.max(a, b);
- }
- }
- /**
- * <p>
- * 得到两个float中最小的一个。
- * </p>
- *
- * @param a
- * 值 1
- * @param b
- * 值 2
- * @return double值最小的
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static float getMin(float a, float b) {
- if (Float.isNaN(a)) {
- return b;
- } else if (Float.isNaN(b)) {
- return a;
- } else {
- return Math.min(a, b);
- }
- }
- /**
- * <p>
- * 返回数组中最小的数值。
- * </p>
- *
- * @param array
- * 数组不能为null,也不能为空。
- * @return 数组里面最小的float
- * @throws IllegalArgumentException
- * 如果<code>数组</code>是<code>null</code>
- * @throws IllegalArgumentException
- * 如果<code>数组</code>是空
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static float getMin(float[] array) {
- // Validates input
- if (array == null) {
- throw new IllegalArgumentException("数组不能为null。");
- } else if (array.length == 0) {
- throw new IllegalArgumentException("数组不能为空。");
- }
- // Finds and returns min
- float min = array[0];
- for (int i = 1; i < array.length; i++) {
- min = getMin(array[i], min);
- }
- return min;
- }
- /**
- * <p>
- * 返回数组中最小的double。
- * </p>
- *
- * @param array
- * 数组不能为null,也不能为空。
- * @return 数组里面最小的double
- * @throws IllegalArgumentException
- * 如果<code>数组</code>是<code>null</code>
- * @throws IllegalArgumentException
- * 如果<code>数组</code>是空
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double getMin(double[] array) {
- // Validates input
- if (array == null) {
- throw new IllegalArgumentException("数组不能为null。");
- } else if (array.length == 0) {
- throw new IllegalArgumentException("数组不能为空。");
- }
- // Finds and returns min
- double min = array[0];
- for (int i = 1; i < array.length; i++) {
- min = getMin(array[i], min);
- }
- return min;
- }
- /**
- * <p>
- * 得到两个double中最小的一个。
- * </p>
- *
- * @param a
- * 值 1
- * @param b
- * 值 2
- * @return double值最小的
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double getMin(double a, double b) {
- if (Double.isNaN(a)) {
- return b;
- } else if (Double.isNaN(b)) {
- return a;
- } else {
- return Math.min(a, b);
- }
- }
- /**
- * 返回两个double的商 first除以second。
- *
- * @param first
- * 第一个double
- * @param second
- * 第二个double
- * @return double
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double divideDouble(double first, double second) {
- BigDecimal b1 = new BigDecimal(first);
- BigDecimal b2 = new BigDecimal(second);
- return b1.divide(b2).doubleValue();
- }
- /**
- * 返回两个double的乘积 first*second。
- *
- * @param first
- * 第一个double
- * @param second
- * 第二个double
- * @return double
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double multiplyDouble(double first, double second) {
- BigDecimal b1 = new BigDecimal(first);
- BigDecimal b2 = new BigDecimal(second);
- return b1.multiply(b2).doubleValue();
- }
- /**
- * 返回两个double的差值 first-second。
- *
- * @param first
- * 第一个double
- * @param second
- * 第二个double
- * @return double
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double subtractDouble(double first, double second) {
- BigDecimal b1 = new BigDecimal(first);
- BigDecimal b2 = new BigDecimal(second);
- return b1.subtract(b2).doubleValue();
- }
- /**
- * 返回两个double的和值 first+second。
- *
- * @param first
- * 第一个double
- * @param second
- * 第二个double
- * @return double
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static double sumDouble(double first, double second) {
- BigDecimal b1 = new BigDecimal(first);
- BigDecimal b2 = new BigDecimal(second);
- return b1.add(b2).doubleValue();
- }
- /**
- * 格式化double指定位数小数。例如将11.123格式化为11.1。
- *
- * @param value
- * 原double数字。
- * @param decimals
- * 小数位数。
- * @return 格式化后的double,注意为硬格式化不存在四舍五入。
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static String formatDouble(double value, int decimals) {
- String doubleStr = "" + value;
- int index = doubleStr.indexOf(".") != -1 ? doubleStr.indexOf(".")
- : doubleStr.indexOf(",");
- // Decimal point can not be found...
- if (index == -1)
- return doubleStr;
- // Truncate all decimals
- if (decimals == 0) {
- return doubleStr.substring(0, index);
- }
- int len = index + decimals + 1;
- if (len >= doubleStr.length())
- len = doubleStr.length();
- double d = Double.parseDouble(doubleStr.substring(0, len));
- return String.valueOf(d);
- }
- /**
- * 生成一个指定位数的随机数,并将其转换为字符串作为函数的返回值。
- *
- * @param numberLength
- * 随机数的位数。
- * @return String 注意随机数可能以0开头。
- * @author 宋立君
- * @date 2014年06月25日
- */
- public static String randomNumber(int numberLength) {
- // 记录生成的每一位随机数
- StringBuffer sb = new StringBuffer();
- for (int i = 0; i < numberLength; i++) {
- // 每次生成一位,随机生成一个0-10之间的随机数,不含10。
- Double ranDouble = Math.floor(Math.random() * 10);
- sb.append(ranDouble.intValue());
- }
- return sb.toString();
- }
- /**
- * 功能:生成一个在最大数和最小数之间的随机数。会出现最小数,但不会出现最大数。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param minNum
- * 最小数
- * @param maxNum
- * 最大数
- * @return int
- */
- public static int randomNumber(int minNum, int maxNum) {
- if (maxNum <= minNum) {
- throw new RuntimeException("maxNum必须大于minNum!");
- }
- // 计算出来差值
- int subtract = maxNum - minNum;
- Double ranDouble = Math.floor(Math.random() * subtract);
- return ranDouble.intValue() + minNum;
- }
- /**
- * 功能:生成一个在最大数和最小数之间的随机数。会出现最小数,但不会出现最大数。<br/>
- * 但不随机notin数组中指定的数字, 如果可随机的范围较小,可能会一直随机不到,或者随机的很慢。
- *
- * @author 宋立君
- * @date 2014年06月25日
- * @param minNum
- * 最小数
- * @param maxNum
- * 最大数
- * @param notin
- * 不随机数组这些数字
- * @return int
- */
- public static int randomNumber(int minNum, int maxNum, Integer[] notin) {
- if (notin.length >= (maxNum - minNum)) {
- throw new RuntimeException("notin数组的元素已经把可以随机的都排除了,无法得到随机数!");
- }
- while (true) {
- int num = randomNumber(minNum, maxNum);
- if (!CollectionUtil.arrayContain(notin, num)) {
- return num;
- }
- }
- }
- }
0 0
- Java工作中常用工具类总结一
- Java常用工具类总结(一)
- Java中常用工具类
- Java常用工具类整理一
- java常用工具类(一)
- Java常用工具类(一)
- Java常用工具类总结(二)
- Java常用工具类总结(三)
- java常用工具类组件 总结
- 工作中常用工具
- Java工作利器之常用工具类(一)——数字工具类-数字转汉字
- java中常用工具类【1】
- Java中常用工具类(效率)
- java中并发常用工具类
- Android开发中常用工具类总结
- [转]Android开发中常用工具类总结
- Android开发中常用工具类总结
- 开发中常用工具类总结-字符串相关
- Hdu2037 - 今年暑假不AC - 贪心算法
- http协议常用请求头与响应头
- Java工具类总结二
- 验证数字为空
- HDU 1385 Minimum Transport Cost(Floyd+打印字典序最小路径)
- Java工作中常用工具类总结一
- 关于在VS2008和VS2010中禁用及卸载Visual Assist X的方法研究
- 【topcoder第一弹】 SRM 144 Div.2 whatTime
- 画了个Android——Canvas类的使用
- 淘宝商城model部分
- bbed初体验
- android 水平button等宽
- git 的本地基本操作
- C#中将结构类型数据存储到二进制文件中方法