答案:Java中统计单词数量常用split()、StringTokenizer或手动遍历字符。首先使用trim()去除首尾空白,再通过split(“s+”)按正则分割字符串并获取非空元素个数;StringTokenizer可自动忽略多余空格,无需额外处理;手动遍历则通过状态切换判断单词边界,适合高性能需求场景。三种方法分别适用于简单处理、自动分隔和精细控制情况。

统计字符串中的单词数量在Java中可以通过多种方式实现,最常见的是根据空格或其他分隔符来拆分字符串,然后计算有效单词的个数。关键在于处理多余的空格(如首尾空格、连续空格)并确保只计有效的词。
使用split()方法按空格分割
利用String的split()方法,通过正则表达式将字符串按空白字符分割成数组,再统计非空元素的数量。
示例代码:
public class WordCount {
public static int countWords(String str) {
if (str == null || str.trim().isEmpty()) {
return 0;
}
String[] words = str.trim().split("s+");
return words.length;
}
public static void main(String[] args) {
String text = " Hello world from Java ";
System.out.println("单词数量: " + countWords(text)); // 输出: 4
}
}
说明:
– trim() 去除首尾空白。
– “s+” 是正则表达式,匹配一个或多个空白字符(包括空格、制表符等)。
– 分割后得到的数组每个元素是一个单词,数组长度即为单词数。
使用StringTokenizer类
Java提供了一个专门处理字符串分词的工具类 StringTokenizer,它可以自动忽略连续的分隔符。
立即学习“Java免费学习笔记(深入)”;
示例代码:
import java.util.StringTokenizer;
public class WordCountWithTokenizer {
public static int countWords(String str) {
if (str == null || str.isEmpty()) {
return 0;
}
StringTokenizer tokens = new StringTokenizer(str);
return tokens.countTokens();
}
public static void main(String[] args) {
String text = "Java is great!";
System.out.println("单词数量: " + countWords(text)); // 输出: 3
}
}
优点: 自动处理多余空格,无需手动 trim 或正则处理。
手动遍历字符判断单词边界
适用于需要更精细控制的场景,比如自定义哪些字符算作分隔符。
思路:
遍历字符串,通过是否从非空格字符转为空格(或反之)来判断单词开始与结束。
示例代码:
public static int countWordsManually(String str) {
if (str == null || str.isEmpty()) return 0;
int count = 0;
boolean inWord = false;
for (char c : str.toCharArray()) {
if (c != ' ') {
if (!inWord) {
count++;
inWord = true;
}
} else {
inWord = false;
}
}
return count;
}
这种方式效率高,适合对性能要求较高的场景。
基本上就这些常用方法。选择哪种取决于你的需求:简单场景用 split 或 StringTokenizer,复杂控制可用手动遍历。
以上就是Java中如何统计字符串中的单词数量的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/198076.html
微信扫一扫
支付宝扫一扫