(已解决)10进制转换成64进制请大侠翻译一下成autoit
本帖最后由 scorpio1102 于 2013-9-27 14:33 编辑网上找的64进制的实现代码如下:
byte数组转换为64进制char数组
public static char[] encode64Digit(byte[] bytes) {
char[] out = new char;
for (int i = 0, j = 0; i < bytes.length; i++) {
out = digits64[(0xC0 & bytes) >>> 6];
out = digits64];
}
return out;
}
64进制char数组转换为byte数组
public static byte[] decode64Digit(char[] chars) {
if ((0x01 & chars.length) != 0) {
return null;
}
byte[] out = new byte;
for (int i = 0, j = 0; j < chars.length; i++) {
int a = (getSize(chars) << 6);
j++;
int b = getSize(chars) & 0xFF;
a = (a | getSize(chars));
j++;
out = (byte) (a & 0xFF);
}
return out;
}
以下Apache的commons-codec项目中针对16进制转换的方法代码如下:
public static char[] encodeHex(byte[] data) {
int l = data.length;
char[] out = new char;
// two characters form the hex value.
for (int i = 0, j = 0; i < l; i++) {
out = DIGITS[(0xF0 & data) >>> 4 ];
out = DIGITS[ 0x0F & data ];
}
return out;
} 本帖最后由 user3000 于 2013-9-24 22:56 编辑
我很想知道,>>>这个是什么运算?
网上搜了下:
“>>> 无符号右移,高位补0”; 与>>类似 回复 2# user3000
这是C++吧 完全不知道里面为什么要去这样运算,能力不够呀,有谁帮忙翻译一下呀. 回复 3# scorpio1102
移位操作比乘除要快得多..
2^6 = 64 本帖最后由 scorpio1102 于 2013-9-27 14:12 编辑
回复 4# annybaby
这个听说过,只是想偷懒一下,希望有人整段翻译成autoit 搜索到有人之前问过类似的问题
http://www.autoitx.com/forum.php?mod=viewthread&tid=32999&highlight=10%BD%F8%D6%C6
页:
[1]