怀疑你是不是并发访问cmds 和 cmdList
如果单线程应该是不会有这种问题的:
cmds.add(command.toString()); //在这一行报了个java.lang.ArrayIndexOutOfBoundsException: -1
还有一个remove时越界异常:
while (cmdList.size() > 0){
String cmd = cmdList.remove(0); //这儿也报越界异常
}
ArrayList add实现
[code="java"] public boolean add(E e) {
ensureCapacity(size + 1); // Increments modCount!!
elementData[size++] = e;
return true;
}[/code]
可能 size 超过int大小 造成负数引起 你看看 异常 索引多大
ArrayList的size 和 remove实现
[code="java"]public E remove(int index) {
RangeCheck(index);
modCount++;
E oldValue = (E) elementData[index];
int numMoved = size - index - 1;
if (numMoved > 0)
System.arraycopy(elementData, index+1, elementData, index,
numMoved);
elementData[--size] = null; // Let gc do its work
return oldValue;
}
private void RangeCheck(int index) {
if (index >= size)
throw new IndexOutOfBoundsException(
"Index: "+index+", Size: "+size);
}
[/code]
1、RangeCheck 如果index >=size 抛出越界;
2、elementData[--size] 如果size=0 抛出
3、如果index<0抛出
你的代码
while (cmdList.size() > 0){ //当size() > 0 在该点单线程的话绝对不会出现size=0 而且index >=0 没有问题的
String cmd = cmdList.remove(0); //移除第0个
}
可能是多线程并发访问造成的,建议
1、List cmds = new ArrayList(TerminalMaps.terminal_commands.get(mac)); ---做个副本
2、cmdList也一样做个本地副本