对于几个相应控件习惯用二分法定位index,这样最省事了

private static final int btnIds[] = {R.id.btn0 ,R.id.btn1 
		,R.id.btn2 ,R.id.btn3 ,R.id.btn4};
int index = Arrays.binarySearch(btnIds, v.getId());

之前一直没问题,直到今天调了下布局控件的上下顺序,btn3和btn4移到上方,然后再测试就一直返回 -1 了.很郁闷.看R文件发现

        public static final int btn0=0x7f060071;
        public static final int btn1=0x7f060072;
        public static final int btn2=0x7f060073;
        public static final int btn3=0x7f06006f;
        public static final int btn4=0x7f060070;

btnIds不是按大小排序了.看到API里有一句

使用二分搜索法来搜索指定的 int 型数组,以获得指定的值。必须在进行此调用之前对数组进行排序(通过 sort(int[]) 方法)。如果没有对数组进行排序,则结果是不确定的。如果数组包含多个带有指定值的元素,则无法保证找到的是哪一个。

试了下

Arrays.sort(btnIds);

j_0064.gif点击 btn3返回0,按大小给排序了.

好吧,只能改一下别的方法了...