最近项目接到一个需求,打印机在打印比较大的数据的时候,经常会打印失败,原因应该与打印机的数据缓冲区的大小有关,于是需要对发送给打印机的byte[]数组做拆分,然后分块发给打印机.
思路:
1)首先根据设置的块的大小计算出拆分后的块的数量
2)建立一个对象为List的集合
3)把数据经过拆分重新组合成List
/**
* @param ary 拆分的数组
* @param blockSize 拆分块的大小
* @return
*/
public static List<List<Byte>> splitAry(byte[] ary, int blockSize) {
int count = ary.length % blockSize == 0 ? ary.length / blockSize : ary.length / blockSize + 1;
Log.i(TAG, "splitAry blockSize:" + blockSize + " count:" + count);
List<List<Byte>> subAryList = new ArrayList<List<Byte>>();
for (int i = 0; i < count; i++) {
int index = i * blockSize;
List<Byte> list = new ArrayList<Byte>();
int j = 0;
while (j < blockSize && index < ary.length) {
list.add(ary[index++]);
j++;
}
subAryList.add(list);
}
return subAryList;
}