由于项目需要把一个ID(数字)压缩成尽可能短字符串,在网上找来好久没有找到合适,
自己动手写一个。
有需要的可以参考一下,也作为自己的一些积累吧!
代码如下:
/**
* 64进制和10进制的转换类
* @author Administrator
*
*/
public class compressEncodeing {
final static char[] digits = {
'0' , '1' , '2' , '3' , '4' , '5' ,
'6' , '7' , '8' , '9' , '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' , '+' , '/' ,
};
/**
* @param args
*/
public static void main(String[] args) {
System.out.println(CompressNumber(999999999999999999L,6));
System.out.println(UnCompressNumber(CompressNumber(999999999999999999L,6)));
}
/**
* 把10进制的数字转换成64进制
* @param number
* @param shift
* @return
*/
private static String CompressNumber(long number, int shift) {
char[] buf = new char[64];
int charPos = 64;
int radix = 1 << shift;
long mask = radix - 1;
do {
buf[--charPos] = digits[(int)(number & mask)];
number >>>= shift;
} while (number != 0);
return new String(buf, charPos, (64 - charPos));
}
/**
* 把64进制的字符串转换成10进制
* @param decompStr
* @return
*/
private static long UnCompressNumber(String decompStr)
{
long result=0;
for (int i = decompStr.length()-1; i >=0; i--) {
if(i==decompStr.length()-1)
{
result+=getCharIndexNum(decompStr.charAt(i));
continue;
}
for (int j = 0; j < digits.length; j++) {
if(decompStr.charAt(i)==digits[j])
{
result+=((long)j)<<6*(decompStr.length()-1-i);
}
}
}
return result;
}
/**
*
* @param ch
* @return
*/
private static long getCharIndexNum(char ch)
{
int num=((int)ch);
if(num>=48&&num<=57)
{
return num-48;
}
else if(num>=97&&num<=122)
{
return num-87;
}else if(num>=65&&num<=90)
{
return num-29;
}else if(num==43)
{
return 62;
}
else if (num == 47)
{
return 63;
}
return 0;
}
}
分享到:
相关推荐
中文转换成十六进制编码中文转换成十六进制编码
二进制 十进制 十六进制 编码转换 源码
进制编码转换器
字符进制编码转换工具,很实用的进制、编码,MD5查询转换工具。
字符和的转换工具 字符和二进制的转换工具
红客联盟学生组G组工具。 编码进制全能转换工具....
16进制编码转换工具.zip
Hex十六进制/Base64编码转换器,可对字符串文本进行十六进制及Base64编码与反编码
需要一个二进制与BASE64相互转换的函数,从网上找...示例中提供二进制与16进制字符串转换函数ConvertHexStrToBin与ConvertBinToHexStr,二进制与BASE64编码转换函数Base64Encode与Base64Decode,在VC6下编译通过可用。
十六进制与时间转换器工具,方便分析数据包等用途
进制转换器v1.0 各种 编码进制转换 可最小化 可快捷键隐藏显示
本程序,是十进制转四进制的 转换器 含有源代码 如需 16进制 8进制 或者其他进制转换 4进制。 可以 用Windows计算机器 先将16进制 或者 8进制 转换为 10进制 再有本程序,转换为四进制。即可。 程序,是直接,10...
软件介绍: 曼彻斯特编码解码器包含转换模式:802.3曼彻斯特、标准曼彻斯特、差分、曼彻斯特编码是否进行每8位反序解码(特殊情况)解码操作按照1-2-3的顺序进行。
HxD是一款简单的十六进制编码处理软件。通过HxD可以快速打开大容量的文件,还能够进行基本的十六进制编码处理操作。HxD Hex Editor软件支持编辑、剪切、复制、粘贴、插入或删除文件数据等功能,满足用户的多种编辑...
对输入的二进制序列编码转换为:HDB3码
【ASP.NET编程知识】Asp.Net中的字符串和HTML十进制编码转换实现代码.docx
支持任意进制转换,字节集,网页编码BASE64编码,UNICODE编码,MD5加密等功能
适用于将二进制数转换为十进制,A为十进制,B为二进制。{A,B}每次左移一位,判断A的每四位是否>4,若大于四则+3,否则保持不变;B为多少位二进制数则左移多少次。最终A是B转换成十进制的数。代码为32位二进制数转换...