二分搜索法 Arrays.binarySearch遇到返回-1的问题
对于几个相应控件习惯用二分法定位index,这样最省事了
privatestaticfinalintbtnIds[]={R.id.btn0,R.id.btn1,R.id.btn2,R.id.btn3,R.id.btn4};intindex=Arrays.binarySearch(btnIds,v.getId());
之前一直没问题,直到今天调了下布局控件的上下顺序,btn3和btn4移到上方,然后再测试就一直返回 -1 了.很郁闷.看R文件发现
publicstaticfinalintbtn0=0x7f060071;publicstaticfinalintbtn1=0x7f060072;publicstaticfinalintbtn2=0x7f060073;publicstaticfinalintbtn3=0x7f06006f;publicstaticfinalintbtn4=0x7f060070;
btnIds不是按大小排序了.看到API里有一句
使用二分搜索法来搜索指定的int型数组,以获得指定的值。必须在进行此调用之前对数组进行排序(通过sort(int[])方法)。如果没有对数组进行排序,则结果是不确定的。如果数组包含多个带有指定值的元素,则无法保证找到的是哪一个。
试了下
Arrays.sort(btnIds);
点击 btn3返回0,按大小给排序了.
好吧,只能改一下别的方法了...
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。