我是靠谱客的博主 大力丝袜,最近开发中收集的这篇文章主要介绍深入剖析Java中String类的concat方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Java String类的concat方法

在了解concat()之前,首先需要明确的是

String的两点特殊性

  • 长度不可变
  • 值不可变

这两点从源码中对String的声明可以体现:

private final char[] value ;

其中final对应值的不可更改的特性;而char[]对应String是长度不可更改的特性。

因此,当我们对String进行拼接后,产生的应该是一个新的字符串。

对于这一点,我们可以对concat()进行源码的解读得出同样的结论。

  • @param str 需要拼接到原字符串的新串
  • @param otherlen 新串的长度
  • @param len 原字符串的长度
  • @param buf 存放最终字符串的字符数组(长度为len+otherlen)
@method  copyOf(char[] original, int newLength) 

复制指定的数组,截取或用 null 字符填充(如有必要),以使副本具有指定的长度。

@method getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin) 

将字符从此字符串复制到目标字符数组。

public String concat(String str) {
        int otherLen = str.length();
        if (otherLen == 0) {
            return this;
        }
        int len = value.length;
        char buf[] = Arrays.copyOf(value, len + otherLen);
        str.getChars(buf, len);
        return new String(buf, true);
    }

源码分析

concat()方法首先获取拼接字符串的长度,判断这个字符串长度是否为0(判断这个用来拼接的字符串是不是空串),如果是就返回原来的字符串(等于没有拼接);否则就获取源字符串的长度,创建一个新的char[]字符数组,这个字符数组的长度是拼接字符串的长度与源字符串的长度之和,通过Arrays类的copyOf方法复制源数组,然后通过getChars方法将拼接字符串拼接到源字符串中,然后将新串返回。

API中也对这个方法进行了解释:

如果参数字符串的长度为 0,则返回此 String 对象。

否则,创建一个新的 String对象,用来表示由此 String 对象表示的字符序列和参数字符串表示的字符序列连接而成的字符序列。

综上,当对String对象进行拼接时,会创建一个新的字符串来存储新串。

String类中concat()方法笔记及底层实现

public String concat(String str)

将指定字符串连接到此字符串的结尾,需要创建对象才能够调用该方法,返回值为字符串。

public  String  concat1(String s){
  String a = new String("jijeufh");
  char [] b = new char[a.length()];
  char [] d =  new char[b.length+s.length()];
  //创建一个能够容纳两个数组长度的数组
   a.getChars(0,b.length,d,0);
   //使用getChars方法,将对象数组中赋值到新的数组中,偏移量为0;
   s.getChars(0, s.length(), d, b.length);
   //使用getChars()方法将,参数数组赋值到新的数组中,偏移量对象数组的长度。
   String dd = new String(d);
   //通过String构造器将数组转换成为新的字符串。
   return dd;
  }
 ```

以上为个人经验,希望能给大家一个参考,也希望大家多多支持靠谱客。

最后

以上就是大力丝袜为你收集整理的深入剖析Java中String类的concat方法的全部内容,希望文章能够帮你解决深入剖析Java中String类的concat方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(121)

评论列表共有 0 条评论

立即
投稿
返回
顶部