`
samuschen
  • 浏览: 407699 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

Java中Array与ArrayList的主要区别

阅读更多

1 )精辟阐述:
可以将 ArrayList 想象成一种 会自动扩增容量的Array”

2Array[] ):最高效;但是其容量固定且无法动态改变;
     ArrayList :  容量可动态增长;但牺牲效率;

3 )建议:
基于效率和类型检验,应尽可能使用Array 无法确定数组大小时才使用ArrayList
不过当你试着解决更一般化的问题时,Array 的功能就可能过于受限。

4Java 中一切皆对象,Array 也是对象。不论你所使用得Array 型别为何,

Array 名称本身实际上是个reference ,指向heap 之内得某个实际对象。

这个对象可经由“Array 初始化语法 被自动产生,也可以以new 表达式手动产生。

5Array 可做为函数返回值 ,因为它本身是对象的reference

6) 对象数组与基本类型数组在运用上几乎一模一样,唯一差别在于,前者持有得是reference ,后者直接持有基本型别之值;
例如:
string [] staff=new string[100];
int [] num=new int[10];

7
)容器所持有的其实是一个个reference 指向Object ,进而才能存储任意型别。当然这不包括基本型别,因为基本型别并不继承自任何classes

8 )面对Array ,我们可以直接持有基本型别数值的Array (例如:int [] num;), 也可以持有reference (指向对象)的Array ;但是容器类仅能持有reference (指向对象),若要将基本型别置于容器内,需要使用wrapper 类。但是wrapper 类使用起来可能不很容易上手,此外,primitives Array 的效率比起 容纳基本型别之外覆类(的reference 的容器好太多了。

当然,如果你的操作对象是基本型别,而且需要在空间不足时自动扩增容量,Array 便不适合,此时就得使用外覆类的容器了。

9 )某些情况下,容器类即使没有转型至原来的型别,仍然可以运作无误。有一种情况尤其特别:编译器对String class 提供了一些额外的支持,使它可以平滑运作。

10 )对数组的一些基本操作,像排序、搜索与比较等是很常见的。因此在Java 中提供了Arrays 类协助这几个操作:sort(),binarySearch(),equals(),fill(),asList().

不过Arrays 类没有提供删除方法,而ArrayList 中有remove() 方法,不知道是否是不需要在Array 中做删除等操作的原因(因为此时应该使用链表)。

11ArrayList 的使用也很简单:产生ArrayList ,利用add() 将对象置入,利用get(i )配合索引值将它们取出。这一切就和Array 的使用方式完全相同,只不过少了[] 而已。

2. 参考资料:
1 )效率:
数组扩容是对ArrayList 效率影响比较大的一个因素。
每当执行AddAddRangeInsertInsertRange 等添加元素的方法,都会检查内部数组的容量是否不够了 ,如果是,它就会以当前容量的两倍来重新构建一个数组,将旧元素Copy 到新数组中,然后丢弃旧数组,在这个临界点的扩容操作,应该来说是比较影响效率的。

ArrayListArray 的复杂版本
ArrayList 内部封装了一个Object 类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList 的许多方法,如IndexIndexOfContainsSort 等都是在内部数组的基础上直接调用Array 的对应方法。

2 )类型识别:
ArrayList 存入对象时,抛弃类型信息,所有对象屏蔽为Object ,编译时不检查类型,但是运行时会报错。
ArrayList 与数组的区别主要就是由于动态增容的效率问题了

3ArrayList 可以存任何Object ,如String 等。

分享到:
评论

相关推荐

    Java Array与ArrayList区别详解

    Java中的Array和ArrayList是两种不同的数据结构,它们在使用场景和特性上有显著的差异。Array是一种固定大小的数据结构,用于存储同一类型的元素序列,而ArrayList是Java集合框架的一部分,属于List接口的一个实现,...

    Java的Array和ArrayList教程by程谱CodeRecipe,适合学过Java入门教程的初学者使用

    在Java编程语言中,Array和ArrayList是两种不同的数据结构,它们都用于存储和管理一组对象。Array是最基本的数组类型,而ArrayList是Java集合框架的一部分,属于动态数组。本教程由程谱CodeRecipe提供,旨在帮助已经...

    详谈Array和ArrayList的区别与联系

    Array和ArrayList的区别与联系 Array是Java中的数组,它是相同数据类型的集合,声明时必须指定数据类型和大小,数组的元素个数是固定的。数组有三种声明方式:int[] a = new int[10]; int a[] = new int[10]; int a...

    用java自己实现的arrayList

    用java自己实现的arrayList,比较详细,有助于初学者理解arrayList的基本概念和基础用法

    java中array用法

    简单的介绍array的基本用法. 注:不是ArrayList!

    java中数组列表ArrayList的使用.doc

    ### Java中数组列表ArrayList的使用详解 #### 一、ArrayList简介 `ArrayList`是Java集合框架中的一个重要组成部分,属于`List`接口的一种实现。它提供了一种动态调整大小的数组,能够有效地存储和操作一系列元素。`...

    跟我学Java-day14-ArrayList集合.pdf

    day14-ArrayList集合 1.ArrayList 1.1ArrayList类概述【理解】 什么是集合 提供一种存储空间可变的存储模型,存储的数据容量可以发生改变 ArrayList集合的特点 ...底层是数组实现的,长度可以...array.add("java");

    java中ArrayList的用法

    ### Java中ArrayList的用法详解 #### 一、概述 `ArrayList`是Java集合框架中的一个动态数组类,它能够存储任意类型的对象,并且在运行时动态调整其大小。这使得`ArrayList`成为处理数量未知的数据集合时的一个非常...

    Vector 与ArrayList区别

    ### Vector 与 ArrayList 的区别详解 #### 一、前言 在 Java 集合框架中,`Vector` 和 `ArrayList` 是两种常用的动态数组实现。它们提供了灵活的数据存储方式,能够根据需要自动调整大小。然而,这两种类型的列表...

    java ArrayList的使用与分析

    【Java ArrayList 使用与分析】 ArrayList 是 Java 集合框架中的一个重要组成部分,它是一个基于数组实现的可变大小的列表。ArrayList 类继承自 AbstractList 类并实现了 List 接口,这意味着它可以被用作一个有序...

    java List、Set与Array之间的相互转换

    以下将详细介绍Java中List、Set与Array之间的转换方法。 1. **List与Array的转换** - **Array转List**: 如果你有一个数组,可以使用`Arrays.asList()`方法将其转换为List。例如: ```java String[] array = {...

    jarraypool:Java Array和ArrayList池,包括堆池,不安全池

    Jarraypool Java Array和ArrayList池Factory,支持非池化堆,非池化不安全,堆池,不安全池。 数组:IntArray,LongArray,ShortArray,CharArray,BooleanArray,StrArray,DecimalArray ArrayList:IntArrayList,...

    Java中ArrayList类的用法.docx

    在Java编程语言中,ArrayList是基于数组实现的一种动态列表,属于集合框架的一部分,它允许程序员在列表的任何位置插入和删除元素。ArrayList类是Java.util包中的一个成员,继承自AbstractList并实现了List接口,...

    Java中ArrayList类的用法知识.pdf

    Java中的ArrayList类是Java集合框架的一部分,它是List接口的一个实现,主要用于存储可变大小的有序对象集合。ArrayList基于数组实现,允许动态地增加或减少元素,提供了丰富的操作方法,适用于需要频繁增删元素的...

    DynamicArray:它基本上是我们在Java中看到的ArrayList

    动态数组在Java编程语言中,通常以ArrayList类的形式存在,它是集合框架的一部分,位于`java.util`包下。ArrayList是一个基于数组实现的可变大小的列表,它允许我们在列表的任何位置插入、删除和查找元素。这篇内容...

    java-array.zip_源代码;array

    5. `ArrayList`与`LinkedList`的区别:`ArrayList`基于动态数组,插入和删除效率相对较低,但随机访问速度快;`LinkedList`基于双向链表,插入和删除效率高,但随机访问慢。 三、函数操作 1. 方法:Java提供了一...

    ArrayList集合工具类

    ArrayList集合工具类是Java编程语言中的一个重要组成部分,它属于Java集合框架的一部分,主要用来存储一组有序的、可变大小的对象。ArrayList是基于数组实现的,它提供了动态增长的能力,允许我们在列表的任何位置...

    JavaScript 实现基础 ArrayList 功能

    在JavaScript中,ArrayList是一种常见的数据结构,它模拟了Java中的ArrayList功能,允许程序员进行动态数组操作。虽然JavaScript原生不支持ArrayList,但我们可以利用数组(Array)对象来实现类似的功能。下面将详细...

    java使用ArrayList遍历及效率比较实例分析

    在Java编程中,ArrayList是集合框架中常用的动态数组实现,它允许我们以索引的方式访问元素。本篇文章将深入探讨如何使用ArrayList进行遍历,并通过实际案例对比不同遍历方式的效率。 首先,我们来看看四种不同的...

    ArrayList实现对产品CRUD

    在Java编程语言中,ArrayList是Java集合框架的重要组成部分,它属于List接口的一个具体实现,用于存储可变大小的有序对象列表。在这个“ArrayList实现对产品CRUD”的项目中,我们将探讨如何利用面向对象编程(OOP)...

Global site tag (gtag.js) - Google Analytics