zoukankan      html  css  js  c++  java
  • java 中 Stringbuff append源代码浅析

     public synchronized StringBuffer append(String str) {
            super.append(str);
            return this;
        } // 同步方法

      public AbstractStringBuilder append(String str) {
            if (str == null) str = "null";
            int len = str.length();
            ensureCapacityInternal(count + len);  // 是否扩容数组,如果扩容,返回将原数据拷入进去的数组
            str.getChars(0, len, value, count);      // 将str拷贝进数组
            count += len;
            return this;
        }

      private void ensureCapacityInternal(int minimumCapacity) {
            // overflow-conscious code
            if (minimumCapacity - value.length > 0) // 原数组中数据内容长度+ 新需要拷贝的字符串长度超过原数组长度需要扩容
                expandCapacity(minimumCapacity);
        }

     void expandCapacity(int minimumCapacity) {
            int newCapacity = value.length * 2 + 2;   // 扩容按照原数组长度的2 * len + 2 的比例
            if (newCapacity - minimumCapacity < 0)
                newCapacity = minimumCapacity;  // 在需要append的字符串很长的情况下会出现
            if (newCapacity < 0) { //  oom
                if (minimumCapacity < 0) // overflow
                    throw new OutOfMemoryError();
                newCapacity = Integer.MAX_VALUE;
            }
            value = Arrays.copyOf(value, newCapacity);  // 将原数据拷贝进一个扩容后的数组返回
        }

    参考源代码,自己在工程代码中简单实现了功能.

          byte[] bytes = new byte[16]; // StringBuff源代码默认初始化是16字节
            String str = "hellowewewehellowewewe";  //  
            bytes = Arrays.copyOf(bytes, 100); // 简单扩容, 省略了判断
            str.getBytes(0, str.length(), bytes, 0);
            
            System.out.println(bytes);
            
            for (int i = 0; i < 100; i++){
                System.out.println(bytes[i]);
            }

    顺便提下String

    String str = "test";

    str = str + "abc"; 使用的是StringBuilder对象添加,

    早上大概花了半个小时, 简单看了下,下回有时间再仔细研究

  • 相关阅读:
    【学习笔记 2】单调队列 & 单调栈
    【学习笔记 1】快速幂
    题解P1151
    题解 P6161【[Cnoi2020]高维】
    不知道叫啥的题目1
    神秘题目1
    5.30 模拟赛赛后总结
    矩阵乘法加速图上问题专题总结
    点分治&点分树 复习
    5.26赛后总结
  • 原文地址:https://www.cnblogs.com/chengxin1982/p/3984176.html
Copyright © 2011-2022 走看看