二分搜索法Arrays.binarySearch遇到返回-1的问题-创新互联

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

成都创新互联成都网站建设定制网站制作,是成都网站制作公司,为成都假山制作提供网站建设服务,有成熟的网站定制合作流程,提供网站定制设计服务:原型图制作、网站创意设计、前端HTML5制作、后台程序开发等。成都网站维护热线:13518219792
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);

二分搜索法 Arrays.binarySearch遇到返回-1的问题点击 btn3返回0,按大小给排序了.

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

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网页名称:二分搜索法Arrays.binarySearch遇到返回-1的问题-创新互联
网址分享:http://pwwzsj.com/article/eihpd.html