当前位置:首页 > 文章列表 > 文章 > java教程 > Java字符串截取方法与性能对比

Java字符串截取方法与性能对比

2026-02-07 09:56:35 0浏览 收藏

大家好,我们又见面了啊~本文《Java字符串截取函数详解与性能分析》的内容中将会涉及到等等。如果你正在学习文章相关知识,欢迎关注我,以后会给大家带来更多文章相关文章,希望我们能一起进步!下面就开始本文的正式内容~

substring()最常用但易越界,需校验索引在[0, str.length()]内;split()适合分隔符切分但注意空段和正则性能;StringTokenizer已过时但简单分隔场景仍有低开销优势;strip()仅去空白不截取,需避免链式调用引发NPE。

java截取字符串的函数_String类核心截取API用法与性能分析

substring() 是最常用但容易越界的截取方法

Java 中 substring() 是最直接的字符串截取函数,但它不校验索引合法性——越界会直接抛 StringIndexOutOfBoundsException。尤其在动态计算索引(如配合 indexOf() 或正则匹配结果)时,很容易忽略边界为负或超出长度的情况。

常见错误场景:从日志行中提取中间字段,但某条日志格式异常导致 indexOf() 返回 -1,再传给 substring(-1, 5) 就崩了。

  • 始终先检查起始/结束索引是否在 [0, str.length()] 范围内(注意:结束索引可等于长度,表示截到末尾)
  • 推荐封装一层安全调用,例如:safeSubstring(str, start, end),内部做 Math.max(0, Math.min(start, str.length())) 类处理
  • JDK 7u6 之后 substring() 不再共享底层 char[],内存更可控,但小字符串频繁截取仍可能触发 GC 压力

split() 适合按分隔符切分,但默认丢弃空段且性能敏感

split(String regex) 截取其实是“以分隔符为界切片”,不是传统意义的子串提取。它默认会丢弃末尾连续的空字符串(比如 "a,b,,c,".split(",") 返回长度为 3 的数组),这点常被误认为是 bug。

真正影响性能的是正则编译开销:每次调用 split() 都会隐式编译正则(除非传入已预编译的 Pattern)。对固定字符串分隔符(如逗号、竖线),应优先用 split(",", -1) 并注意第 2 参数控制空段保留逻辑。

  • 固定字符分隔,用 split("\\|", -1)(竖线需转义,-1 表示不限制分割次数且保留空项)
  • 高频调用场景,提前缓存 Pattern.compile(","),再用 pattern.split(str)
  • 纯位置截取别硬套 split()——比如只要第 2 个逗号后的 10 个字符,用 substring() + indexOf() 更轻量

StringTokenizer 已过时,但简单空格/制表符切分仍有低开销优势

StringTokenizer 不是正则驱动,也不创建临时对象,对纯字符集分隔(如 " \t\n\r\f")的遍历式切分,吞吐量比 split() 高 2–3 倍。但它已被 Javadoc 标记为“legacy”,不支持正则、不可扩展,且无法返回空 token。

适用场景非常窄:解析配置文件中由空格分隔的命令行参数,或嵌入式环境里避免正则类加载开销。

  • 仅当确定分隔符是固定字符集、且不需要空项、不需正则能力时才考虑
  • 不要用它处理用户输入或含混合分隔符的文本(比如 CSV 中的引号包裹逗号)
  • 替代方案:Guava 的 Splitter.on(' ').omitEmptyStrings().trimResults() 更安全易读

Java 11+ 的 strip()/stripLeading()/stripTrailing() 不是截取,但常被误用作“去首尾空格后取子串”

这三个方法只移除 Unicode 空白字符(包括全角空格、零宽空格等),不改变字符串内容结构,也不接受索引参数。有人写成 str.strip().substring(0, 10) 想“先清理再取前 10”,但若原始字符串首尾无空白,strip() 会返回原引用,而 substring() 又可能新建对象——看似省事,实则语义混杂、调试困难。

真正需要“清理+截断”组合逻辑时,应显式拆解步骤,并明确空字符串、null、超长等情况的处理策略。

  • 避免链式调用掩盖 null 或长度异常,例如 str.strip().substring(0, N)str 为 null 时直接 NPE
  • 如果目标是“最多取前 N 个非空白字符”,用 str.codePoints().takeWhile(cp -> !Character.isWhitespace(cp)).limit(N).collect(...) 更精准(但代价是流开销)
  • 日常开发中,先 Objects.requireNonNull(str, "input must not be null"),再 str = str.strip(),最后做 substring 或其他操作,逻辑更清晰

字符串截取看着简单,但边界判断、编码感知、GC 影响和 null 安全这四点,几乎每个项目都会踩至少一次。别依赖 IDE 自动补全的 API 文档摘要,打开 JDK 源码看一眼 substring 的索引校验逻辑,比读十篇博客更管用。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

Windows10内存检测工具及使用方法Windows10内存检测工具及使用方法
上一篇
Windows10内存检测工具及使用方法
Python用rembg去背景详细教程
下一篇
Python用rembg去背景详细教程
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3922次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4258次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4140次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    5372次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    4513次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码