public static void main(String[] args) throws Exception{
String str ="xflush3.0我的感受最大的特色就是監控配置很是靈活,從日誌的格式定義、收集、配置,均可以自定義;這樣對於老應用的打點日誌,不須要關心規則的定義就能夠平滑的接入該平臺。 本篇幅以AE detail的應用爲例,介紹一部分業務監控規則的配置方式以及遇到的一些坑。";
System.out.println("\n原始的字符串爲------->" + str);
float len0=str.length();
System.out.println("原始的字符串長度爲------->"+len0);
String ys = compress(str);
System.out.println("\n壓縮後的字符串爲----->" + ys);
float len1=ys.length();
System.out.println("壓縮後的字符串長度爲----->" + len1);
String jy = unCompress(ys);
System.out.println("\n解壓縮後的字符串爲--->" + jy);
System.out.println("解壓縮後的字符串長度爲--->"+jy.length());
System.out.println("\n壓縮比例爲"+len1/len0);
//判斷
if(str.equals(jy)){
System.out.println("先壓縮再解壓之後字符串和原來的是如出一轍的");
}
}
/**
* 字符串的壓縮
*
* @param str
* 待壓縮的字符串
* @return 返回壓縮後的字符串
* @throws IOException
*/
public static String compress(String str) throws IOException {
if (null == str || str.length() <= 0) {
return str;
}
// 建立一個新的 byte 數組輸出流
ByteArrayOutputStream out = new ByteArrayOutputStream();
// 使用默認緩衝區大小建立新的輸出流
GZIPOutputStream gzip = new GZIPOutputStream(out);
// 將 b.length 個字節寫入此輸出流
gzip.write(str.getBytes());
gzip.close();
// 使用指定的 charsetName,經過解碼字節將緩衝區內容轉換爲字符串
return out.toString("ISO-8859-1");
}
/**
* 字符串的解壓
*
* @param str
* 對字符串解壓
* @return 返回解壓縮後的字符串
* @throws IOException
*/
public static String unCompress(String str) throws IOException {
if (null == str || str.length() <= 0) {
return str;
}
// 建立一個新的 byte 數組輸出流
ByteArrayOutputStream out = new ByteArrayOutputStream();
// 建立一個 ByteArrayInputStream,使用 buf 做爲其緩衝區數組
ByteArrayInputStream in = new ByteArrayInputStream(str
.getBytes("ISO-8859-1"));
// 使用默認緩衝區大小建立新的輸入流
GZIPInputStream gzip = new GZIPInputStream(in);
byte[] buffer = new byte[256];
int n = 0;
while ((n = gzip.read(buffer)) >= 0) {// 將未壓縮數據讀入字節數組
// 將指定 byte 數組中從偏移量 off 開始的 len 個字節寫入此 byte數組輸出流
out.write(buffer, 0, n);
}
// 使用指定的 charsetName,經過解碼字節將緩衝區內容轉換爲字符串
return out.toString("UTF-8");
}數組