A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王晓东 初级黑马   /  2012-6-6 12:34  /  1365 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  1. /**16进制字符集**/
  2. private static final char HEX_DIGITS[] = { '0', '1', '2', '3', '4', '5','6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
  3. public static String byteToHex(byte bt) {
  4.     return HEX_DIGITS[(bt & 0xf0) >> 4] + "" + HEX_DIGITS[bt & 0xf];
  5. }
复制代码
谁帮忙解释下原理啊
bt & 0xf0?
(bt & 0xf0) >> 4?
HEX_DIGITS[bt & 0xf]?

评分

参与人数 1技术分 +1 收起 理由
袁錦泰 + 1

查看全部评分

1 个回复

倒序浏览
bt & 0xf0 就是保留bt的高4位, 0xf0就是二进制 11110000, bt跟11110000作&运算,低4位就被清掉,只留下高4位

比如bt的二进制是 01011111,和 0xf0进行&运算,就是 01011111 & 11110000 = 01010000(二进制的&运算LZ应该懂得吧)

(bt & 0xf0) >> 4 就是保留bt的高4位,并右移4位,也就是把bt的高4位移到低4位

HEX_DIGITS[bt & 0xf] 就是bt & 0xf 的结果作为数组的下标,取HEX_DIGITS数组的元素,bt & 0xf就是取bt的低4位,0xf的二进制是00001111,bt跟00001111作&运算,高4位被清空,保留低4位


希望楼主满意

评分

参与人数 1技术分 +1 收起 理由
袁錦泰 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马