百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Java Array 和 String 的转换(java string数组转string)

wptr33 2025-07-28 00:35 18 浏览

英文标题【Array to String Conversions】

概述

本页面中的内容对 Array 和 String 之间互相进行转换的方法进行一些说明。

我们可以使用 原生 Java(vanilla Java) 或者一些第三方的 Java 工具类来实现这个转换。ies.

将 Array 转换为 String

在有时候我们希望将字符串的数字或者整数类型的数组转换为字符串。但是如果我们直接使用 toString() 来进行转换的话,你可能会得到类似下面 Ljava.lang.String;@74a10858 的字符串。

上面的字符串显示的是对象的类型和当前这个对象的哈希代码。

但是, java.util.Arrays 工具类也能够支持一些 toString() 的方法来将 Array 转换为 String。

Arrays.toString() 将输入的数组转换为字符串,在转换后的字符串将会使用逗号分隔符,同时在字符串的前后会添加一个方括号 []。

可以考察下面的代码:

        String[] strArray = {"one", "two", "three"};
        String joinedString = Arrays.toString(strArray);
        assertEquals("[one, two, three]", joinedString);
        
        int[] intArray = {1, 2, 3, 4, 5};
        joinedString = Arrays.toString(intArray);
        assertEquals("[1, 2, 3, 4, 5]", joinedString);

StringBuilder 的 append() 方法

这个是基于 Java 的原生实现,你可以对需要转换的数组进行遍历,然后将遍历的结果使用 append() 方法添加到字符串后面。

        String[] strArray = {"Convert", "Array", "With", "Java"};
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i < strArray.length; i++) {
            stringBuilder.append(strArray[i]);
        }
        String joinedString = stringBuilder.toString();
        assertEquals("ConvertArrayWithJava", joinedString);

另外,如果你的数组中存储的数据是整形的话,那么你可以使用方法转换函数,首先将整数类型转换为字符串后再添加。

Java Streams API

从 Java 8 及其以上的版本,你可以使用 String.join() 方法将给出的数组元素使用不同的连接字符串连接在一起,在我们使用案例中,我们使用空白字符进行连接。

        String joinedString = String.join("", new String[]{"Convert", "With", "Java", "Streams"});
        assertEquals("ConvertWithJavaStreams", joinedString);

更多的是,我们可以使用 Java Streams API 中的 Collectors.joining() 方法来进行连接,这个连接的方法将会保留和输入数据相同的顺序。

        String joinedString = Arrays
                .stream(new String[]{"Convert", "With", "Java", "Streams"})
                .collect(Collectors.joining());
        assertEquals("ConvertWithJavaStreams", joinedString);

StringUtils.join()

Apache Commons Lang 为字符串处理提供了非常好的方法,能够很好的帮我们解决上面的问题。

这个 join 的方法可以通过输入的数据进行自动进行合并,合并的结果与你输入数据的顺序相同。

        String joinedString = StringUtils.join(new String[]{"Convert", "With", "Apache", "Commons"});
        assertEquals("ConvertWithApacheCommons", joinedString);

Joiner.join()

同样的 Guava 也提供了同样的工具类来使用。

例如,我们可以使用下面的代码来对数组进行连接。

String joinedString = Joiner.on("")
        .skipNulls()
        .join(new String[]{ "Convert", "With", "Guava", null });
assertEquals("ConvertWithGuava", joinedString);

将字符串转换为数组

同样的,在有些时候,我们希望能够将字符串转换为数组。

最常用的情况就是有一个输入的字符串,使用特定的分隔符,我们需要按照分隔符的位置将字符串拆分为数组。

String.split()

这个是最简单的方法了,可以直接把字符串中的字符使用给定的字符进行拆分,如下面的代码:

String[] strArray = "loremipsum".split("");

上面的代码将会生成下面的输出,因为我们没有给定任何分隔符,所以这个方法将会按照字符进行拆分。

["l", "o", "r", "e", "m", "i", "p", "s", "u", "m"]

StringUtils.split()

另外,可能用得最多的就是 Apache 的 Commons 中的 StringUtils ,这个能够对指定的字符串进行拆分。

如果使用 String 的方法进行拆分的话,可能会遇到空对象的问题,例如你输入的字符串可能是空字符串,这个时候 String 自带的原生方法将会抛出空异常。

如果使用 StringUtils 方法的话,可以有效的避免空对象的异常,因此这个工具类是非常常用的。在默认的情况下,这个方法使用的是空格作为分隔符。

String[] splitted = StringUtils.split("lorem ipsum dolor sit amet");

上面的方法将会输出下面的数组。

["lorem", "ipsum", "dolor", "sit", "amet"]

Splitter.split()

最后,你还可以使用 Guava 的拆分 API,如果 Apache Commons 提供的方法,通常 Guava 也能提供类似的。

例如我们可以使用下面的方法进行拆分,可以看到的是,我们在拆分的时候可以同时对结果进行处理。

List<String> resultList = Splitter.on(' ')
    .trimResults()
    .omitEmptyStrings()
    .splitToList("lorem ipsum dolor sit amet");   
String[] strArray = resultList.toArray(new String[0]);

上面的代码能够生成下面的结果:

["lorem", "ipsum", "dolor", "sit", "amet"]

结论

本页面对 String 和 Array 之间的转换方法进行了一些说明。一般来说可以使用原生方法进行转换,但是我们通常不建议使用,主要是方法功能比较差,同时还非常容易出现空对象异常。

因此建议使用 Apache Commons 或者 Guava 的相关方法进行转换。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...