在Android / Java中格式化MAC地址,而不会产生不必要的垃圾

前端之家收集整理的这篇文章主要介绍了在Android / Java中格式化MAC地址,而不会产生不必要的垃圾前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在开发一个Android应用程序,它需要每秒处理数千个数据包,同时提取和格式化每个帧的MAC地址.问题是垃圾收集器每秒运行十几次并拖延我的应用程序,这反过来让我错过了数据包.我避免创建新对象(我认为)可能.

我在DDMS中使用了分配跟踪器,并确定要清理的99%的垃圾来自以下方法.这是我正在使用的代码

void parseMac() { 
    hex_sb.setLength(0);

    for (hex_counter = 0; hex_counter < 6; hex_counter++) {
        hex_sb.append(String.format("%02X",parser_packet_bytes[parser_skip + hex_counter])); 
        if (!(hex_counter == 5)) {
            hex_sb.append(":");
        }
    }

    formatted_mac = hex_sb.toString();
}

hex_sb是一个StringBuilder,可以重用. hex_counter是MAC地址中的字节数(字节来自parser_packet_bytes,byte []).如果它不是MAC的最后一个字节,请附加“:”以进行正确的格式化. formatted_mac是一个类范围的String,用于存储格式化的MAC.根据分配跟踪器,唯一的问题是使用String.format的行.

我对StackOverflow专家的问题是:如何重写上述方法,以便创建更少(最好没有)垃圾

最佳答案
而不是使用非常昂贵的String.format(),只需手动附加半字节.不幸的是,数字和字母在ASCII / UTF-8中不是连续的,所以这就是我如何处理它:

static final char HEX_DIGITS[] = "01234567890abcdef".tocharArray();
...
hex_sb.append(HEX_DIGITS[thisByte >> 4]).append(HEX_DIGITS[thisByte & 0xf]);

由于这是一个MAC地址(已知长度)并被称为一大堆,我可能会展开整个事情,包括附加冒号/句点(应该是char,而不是String).如果它真的对速度至关重要,请管理自己的char []并将其提供给String#new(char []).您可以避免以这种方式重新插入分隔符.

猜你在找的Android相关文章