0

0

Java里的Collections.binarySearch如何在高频查找中使用_二分检索前提

P粉602998670

P粉602998670

发布时间:2026-03-02 12:37:11

|

715人浏览过

|

来源于php中文网

原创

binarysearch要求list必须已排序且比较逻辑一致,否则结果不可信;未排序、comparator不匹配、非randomaccess实现(如linkedlist)或误读负数返回值均会导致错误。

java里的collections.binarysearch如何在高频查找中使用_二分检索前提

binarySearch 要求 List 必须已排序,否则结果不可信

这是最常踩的坑:直接对 ArrayList 调用 Collections.binarySearch,却没确认它是否有序。函数本身不校验顺序,只按二分逻辑读取中间元素——如果数据乱序,返回值可能是任意负数(表示插入点),也可能是错误的正索引。

常见错误现象:Collections.binarySearch(list, target) 返回 -1,但你知道 target 确实在列表里;或者返回某个正数索引,但查出来发现是错的元素。

  • 使用场景:适合一次性排序、多次查找的场景,比如配置项白名单、枚举映射表、静态字典
  • 排序必须用和查找时相同的比较逻辑:如果用 String.CASE_INSENSITIVE_ORDER 排序,查找时也得传同一个 Comparator
  • 别依赖 list.sort() 后立刻查——要确保排序完成且未被后续修改

传 Comparator 时必须和排序时完全一致

哪怕只是多一个 nullsFirst() 或少一个 reversed()binarySearch 就会失效。Java 不做兼容性推断,它只机械地执行二分过程,前提是“数组在该 comparator 下单调”。

示例:你用 Comparator.comparing(String::length) 排了序,但查找时传了 Comparator.naturalOrder(),结果必然错。

立即学习Java免费学习笔记(深入)”;

Hotpot AI Background Remover
Hotpot AI Background Remover

Hotpot.ai推出的图片背景移除工具

下载
  • 参数差异:不传 Comparator 表示用元素自身的 Comparable 实现;传了就必须和排序所用实例完全相同(引用相等或语义等价)
  • 容易忽略:Lambda 写法每次都会生成新对象,所以排序和查找都用 Comparator.comparing(String::toLowerCase) 是错的——两次调用产生两个不同实例
  • 稳妥做法:定义为 static final Comparator 字段复用

高频查找下,List 需是 RandomAccess 实现

binarySearch 内部会反复通过 get(int) 访问中间位置。如果传入的是 LinkedList,每次 get 都是 O(n),整个查找退化成 O(n log n),比线性扫描还慢。

性能影响明显:10 万元素的 LinkedList 上二分,可能比 ArrayList 上线性扫描慢 10 倍以上。

  • 检查方式:用 list instanceof RandomAccess 判断,不是就别硬上 binarySearch
  • 替代方案:真要用链式结构+高频查找,考虑先转成 ArrayList,或换 TreeSet/TreeMap
  • 注意:Arrays.asList() 返回的 list 是 RandomAccess,但底层是数组,没问题

返回值不是布尔值,负数含义要手动解析

很多人误以为返回 -1 就代表“没找到”,其实负数表示“应插入的位置”,计算公式是 -(insertionPoint) - 1。直接拿 result 当“不存在”是对的,但若想取插入点,得自己解包。

错误用法:if (index == -1) { /* not found */ } ——漏掉了 -2-3 等所有其他负值。

  • 正确判断存在性:只用 index >= 0
  • 需要插入逻辑时:用 -(index + 1) 得到插入下标
  • 别和 Arrays.binarySearch 混淆:后者行为一致,但类型更明确;而 Collections.binarySearchList 的约束更隐晦

实际用的时候,最容易被绕进去的是“我以为排过序了”,结果中间有并发写入、或排序用的 comparator 和查找不一致、或根本没排序——这些都不会报错,只会静默返回错误结果。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

839

2023.08.22

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

406

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

596

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.15

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4万人学习

C# 教程
C# 教程

共94课时 | 10.5万人学习

Java 教程
Java 教程

共578课时 | 75.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号