Java数组扩容的原理

1)Java数组对象的大小是固定不变的,数组对象是不可扩容的。

2)利用数组复制方法可以变通的实现数组扩容。

3)System.arraycopy()可以复制数组。

4)Arrays.copyOf()可以简便的创建数组副本。

5)创建数组副本的同时将数组长度增加就变通的实现了数组的扩容。

源码展示:

1 public classArrays {

2 /**

3 * @paramoriginal: the array to be copied

4 * @paramnewLength: the length of the copy to be returned

5 * @returna copy of the original array, truncated or padded with zeros

6 * to obtain the specified length

7 */

8 public static int[] copyOf(int[] original, intnewLength) {

9 int[] copy = new int[newLength];

10 System.arraycopy(original, 0, copy, 0,

11 Math.min(original.length, newLength));

12 returncopy;

13 }

14 /**

15 * @paramoriginal the array from which a range is to be copied

16 * @paramfrom the initial index of the range to be copied, inclusive

17 * @paramto the final index of the range to be copied, exclusive.

18 * (This index may lie outside the array.)

19 * @returna new array containing the specified range from the original array,

20 * truncated or padded with zeros to obtain the required length

21 */

22 public static int[] copyOfRange(int[] original, int from, intto) {

23 int newLength = to -from;

24 if (newLength < 0)

25 throw new IllegalArgumentException(from + " > " +to);

26 int[] copy = new int[newLength];

27 System.arraycopy(original, from, copy, 0,

28 Math.min(original.length -from, newLength));

29 returncopy;

30 }

31 }

示例说明:

1 importjava.util.Arrays;

2

3 /**数组变长算法!

4 * 数组对象长度不可改变

5 * 但是很多实际应用需要长度可变的数组

6 * 可以采用复制为容量更大的新数组, 替换原数组, 实现变长操作

7 * */

8 public classArrayExpand {

9 public static voidmain(String[] args) {

10 //数组变长(扩容)算法!

11 int[] ary={1,2,3};

12 ary=Arrays.copyOf(ary, ary.length+1);

13 ary[ary.length-1]=4;

14 System.out.println(Arrays.toString(ary));//[1, 2, 3, 4]

15 //字符串连接原理

16 char[] chs = { '中', '国'};

17 chs = Arrays.copyOf(chs, chs.length + 1);

18 chs[chs.length - 1] = '北';

19 chs = Arrays.copyOf(chs, chs.length + 1);

20 chs[chs.length - 1] = '京';

21 //字符数组按照字符串打印

22 System.out.println(chs);//中国北京

23 //其他数组按照对象打印

24 System.out.println(ary);//[I@4f1d0d

25 }

26 }

实现案例:

案例1 : 统计一个字符在字符串中的所有位置.

字符串: 统计一个字符在字符串中的所有位置

字符: '字'

返回: {4,7}

1 public classCountCharDemo {

2 public static voidmain(String[] args) {

3 char key = '字';

4 String str = "统计一个字符在字符串中的所有位置";

5 int[] count=count(str,key);

6 System.out.println(Arrays.toString(count));//[4, 7]

7 }

8 public static int[] count(String str,charkey){

9 int[] count={};

10 for(int i=0;i

11 char c=str.charAt(i);

12 if(c==key){

13 //扩展数组

14 count=Arrays.copyOf(count, count.length+1);

15 //添加序号i

16 count[count.length-1]=i;

17 }

18 }

19 returncount;

20 }

21 }

char[]、String、StringBuilder

char[]:字符序列, 只有字符数据, 没有操作, 如果算法优秀, 性能最好。

String: char[] + 方法(操作, API功能)

StringBuilder: char[] + 方法(操作char[] 的内容)

String:内部包含内容不可变的char[],表现为String对象不可变。String包含操作(API方法),是对char[]操作,但不改变原对象经常返回新的对象,很多String API提供了复杂的性能优化算法,如:静态字符串池。

StringBuilder:内部也是一个char[],但是这个数组内容是可变的,并且自动维护扩容算法,因为数据内容可变,所以叫:可变字符串。StringBuilder API方法,是动态维护char[]内容,都可以改变char[]内容。

1 public abstract classAbstractStringBuilder {

2 /**The value is used for character storage.*/

3 charvalue[];

4 /**The count is the number of characters used.*/

5 intcount;

6 /**Returns the length (character count).*/

7 public intlength() {

8 returncount;

9 }

10

11 publicAbstractStringBuilder append(String str) {

12 if (str == null)

13 str = "null";

14 int len =str.length();

15 if (len == 0)

16 return this;

17 int newCount = count +len;

18 if (newCount >value.length)

19 expandCapacity(newCount);

20 str.getChars(0, len, value, count);

21 count =newCount;

22 return this;

23 }

24

25 /**

26 * 自动实现Java数组扩容

27 */

28 void expandCapacity(intminimumCapacity) {

29 int newCapacity = (value.length + 1) * 2;

30 if (newCapacity < 0) {

31 newCapacity =Integer.MAX_VALUE;

32 } else if (minimumCapacity >newCapacity) {

33 newCapacity =minimumCapacity;

34 }

35 value =Arrays.copyOf(value, newCapacity);

36 }

37 }

字符串数组与String类的原理

1 /**字符串数组与String类的原理 */

2 public classCharArrayDemo {

3 public static voidmain(String[] args) {

4 /*Java 可以将char[]作为字符串处理 */

5 char[] ch1={'中','国','北','京'};

6 char[] ch2={'欢','迎','您'};

7 System.out.println(ch1);//中国北京

8 System.out.println(ch2);//欢迎您

9 /*char[]运算需要编程处理,如连接: */

10 char[] ch3=Arrays.copyOf(ch1, ch1.length+ch2.length);

11 System.arraycopy(ch2, 0, ch3, ch1.length, ch2.length);

12 System.out.println(ch3);//中国北京欢迎您

13 /*String API提供了简洁的连接运算: */

14 String str1="中国北京";

15 String str2="欢迎您";

16 String str3=str1.concat(str2);

17 System.out.println(str3);//中国北京欢迎您

18 /*字符串转大写: */

19 char[] ch4={'A','a','c','f'};

20 char[] ch5=Arrays.copyOf(ch4, ch4.length);

21 for(int i=0;i

22 char c=ch5[i];

23 if(c>='a' && c<='z'){

24 ch5[i]=(char)(c+('A'-'a'));

25 }

26 }

27 System.out.println(ch5);//AACF, 原数组ch4不变

28 String str4="Aacf";

29 String str5=str4.toUpperCase();//原字符串str4保持不变

30 System.out.println(str5);//AACF

31 }

32 }

java数组可扩展_[转载]Java数组扩容算法及Java对它的应用相关推荐

  1. java 产生p10证书_【国密SM2算法】JAVA创建pkcs10格式的csr证书请求文件

    代码: public static void main(String[] args) throws Exception { Security.addProvider(new org.bouncycas ...

  2. [转载]Java数组扩容算法及Java对它的应用

    原文链接:http://www.cnblogs.com/gw811/archive/2012/10/07/2714252.html Java数组扩容的原理 1)Java数组对象的大小是固定不变的,数组 ...

  3. java 二维数组内存溢出_程序员:学习心得,Java内存区域,内存溢出异常

    Java 内存区域 Heap 线程公有 存放实例对象 是GC主要管理区域,因此可以更细致的划分为:新生代.老年代 再细致一点划分:Eden区.From Survivor区.To Survivor区 内 ...

  4. Java数组扩容算法及Java对它的应用

    1)Java数组对象的大小是固定不变的,数组对象是不可扩容的.利用数组复制方法可以变通的实现数组扩容.System.arraycopy()可以复制数组.Arrays.copyOf()可以简便的创建数组 ...

  5. java中的多态性_[转载] c++多态与java多态性_Java中的多态性

    参考链接: Java中的加法和串联 c++多态与java多态性 Polymorphism is one of the core concepts of OOPS paradigm. The meani ...

  6. 我的世界java版记分板_[转载][娱乐]SimpleScoreboards——计分板插件[全版本]

    2020-02-22 16:11:15.343 [main] ERROR - Throwing java.lang.RuntimeException: while parsing a block co ...

  7. java byte 判断相等_转发收藏 | 史上最全Java面试题+面试网站推荐!(含答案)

    今天要谈的主题是关于求职,求职是在每个技术人员的生涯中都要经历多次.对于我们大部分人而言,在进入自己心仪的公司之前少不了准备工作,有一份全面细致面试题将帮助我们减少许多麻烦. 相关概念 面向对象的三个 ...

  8. Java中合法的关键词_优秀程序员必须掌握的java中50个关键字

    关键字和保留字的区别 正确识别java语言的关键字(keyword)和保留字(reserved word)是十分重要的.Java的关键字对java的编译器有特殊的意义,他们用来表示一种数据类型,或者表 ...

  9. java中验证码发送_实现短信验证码的发送[JAVA]

    如何实现短信验证码的发送 一.基础知识补充 1.编码 2.URL 3.字节流与字符流 二.短信验证码编程实现 一.基础知识补充 1.编码 常见的编码:UTF-8 GBK Unicode GB2312 ...

最新文章

  1. ASP.NET的用户控件
  2. 周末,我打开《逆水寒》参加了一场AI学术会议
  3. php memcache
  4. html约束验证的例子,HTML5利用约束验证API来检查表单的输入数据的代码实例
  5. ASP.NET MVC的ContentResult
  6. 2021最新4合1即时通讯IM源码-服务端+PC+WEB+安卓+IOS完整原生源码
  7. python编程从入门到实践pdf_Python编程入门研读笔记(二)
  8. 加州无人车路测历史性变革!远程遥控,真正无人
  9. 201803-1-跳一跳
  10. TML5期末大作业:美丽家乡网站设计——美丽家乡-含论文(4页) HTML+CSS+JavaScript web前端设计与开发期末作品/期末大作业
  11. 实对称矩阵的特征值求法_实对称矩阵、相似、标准型、合同的逻辑网
  12. 有一种伪仪式感,叫“中国式旅行”
  13. 蓝桥杯练习题之 Fibonacci数列
  14. jQuery UI插件之datepicker的自定义设置
  15. 还在用PDF做简历?落后了!
  16. Port Triggering
  17. 【线性代数】6-7:SVD分解(Singular Value Decomposition-SVD)
  18. 似然函数、最大似然估计简单理解
  19. 一个悄然崛起的国产软件
  20. VSC 注册右键菜单

热门文章

  1. Keras学习代码—github官网examples
  2. (chap1 web网络基础) URI和URL
  3. C++ Primer 5th笔记(chap 12 动态内存)weak_ptr
  4. Kubernetes存储之Secret
  5. scrapy python3.8_银狐DevNet-网络运维Python初篇(四)netmiko抓取华为网络配置并存入本地...
  6. java不使用IDE导入json
  7. 静态反调试技术(2)
  8. [FlareOn5]Ultimate Minesweeper(dnSpy新玩法)
  9. 2020-12-18(何种情况下编译器会提供默认构造函数)
  10. 【Web安全】php://filter 的浅略底层分析