`
sooxin
  • 浏览: 257601 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

数组(array)与ArrayList的主要区别:效率、类型识别和primitive type

    博客分类:
  • J2EE
阅读更多
1.自己的总结:
1)精辟阐述:(《TIJ》第323页)
初学者可以将ArrayList想象成一种“会自动扩增容量的array”。

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

3)建议:(《TIJ》第292页)
基于效率和类型检验,应尽可能使用array,无法确定数组大小时才使用ArrayList!

不过当你试着解决更一般化的问题时,array的功能就可能过于受限。

4)java中一切皆对象,array也是对象。不论你所使用得array型别为何,array名称本身实际上是个reference,指向heap之内得某个实际对象。这个对象可经由“array初始化语法”被自动产生,也可以以new表达式手动产生。(《TIJ》第292页)

5)array可做为函数返回值,因为它本身是对象的reference;(《TIJ》第295页)

6)对象数组与基本类型数组在运用上几乎一模一样,唯一差别在于,前者持有得是reference,后者直接持有基本型别之值;(《TIJ》第292页)
eg.
Employee[] staff=new Employee[100];
int[] num=new int[10];

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

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

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

自己的注释:
jdk5可以自动装包和解包,似乎感觉不到外覆类的存在了。

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

10)你可能会认为应该针对各种基本类型都提供一份特殊版的ArrayList,但java并未如此。有朝一日,某种模板机制也许能帮助java更妥善的处理此一问题。(《TIJ》第295页)

自己的注释:
jdk5已经支持泛型,相当于不仅可以“针对各种基本类型都提供一份特殊版的ArrayList”,并且可以“针对所有型别(包括用户自定义的类,如Employee类)都提供一份特殊版的ArrayList”。

这样,“不能识别型别”已经不再ArrayList的劣势,把不正确的对象置于容器内就会发生编译器错误;而不像以前那样编译期不发生错误,执行期才产生异常,可能会产生难以查觉的程序臭虫。

此外,泛型支持的实现原理可以从“《TIJ》第326页”的“制作一个具有型别意识的ArrayList”的例子中领悟到一二。

11)对数组的一些基本操作,像排序、搜索与比较等是很常见的。因此在Java中提供了Arrays类协助这几个操作:sort(),binarySearch(),equals(),fill(),asList().
(《Java JDK 5.0学习笔记》http://book.csdn.net/bookfiles/135/1001354621.shtml)

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

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

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

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

2)类型识别:
ArrayList存入对象时,抛弃类型信息,所有对象屏蔽为Object,编译时不检查类型,但是运行时会报错。

注:jdk5中加入了对泛型的支持,已经可以在使用ArrayList时进行类型检查。


从这一点上看来,ArrayList与数组的区别主要就是由于动态增容的效率问题了


3)ArrayList可以存任何Object,如String,Employee等,但不支持基本数据类型,除非使用wrapper。
分享到:
评论

相关推荐

    C# Array和ArrayList,List区别

    ### C# 中 Array、ArrayList 和 List 的区别 在C#编程语言中,处理集合数据时,程序员经常需要根据实际需求选择合适的集合类型。本文将详细解释C#中Array、ArrayList和List之间的区别,并通过示例代码帮助理解这些...

    使用数组列表ArrayList填充ListBox

    在.NET框架中,ArrayList是System.Collections命名空间下的一种动态数组,它可以存储任意类型的对象,而ListBox控件则是Windows Forms应用程序中常见的用户界面元素,用于显示一个可选项目的列表。本篇将详细介绍...

    C#中数组与arraylist

    数组与ArrayList的主要区别在于: 1. **类型安全**:数组是静态类型,保证了类型安全;ArrayList是动态类型,可能导致类型错误。 2. **大小**:数组的大小固定,ArrayList的大小可变。 3. **性能**:数组访问更快,...

    .net(c#)中Array和ArrayList的异同点

    Array是最基础的数组类型,它是一种固定大小的数据结构,用于存储相同类型的元素集合。Array中的元素可以通过索引进行访问和修改。 #### 特性: 1. **固定大小**:一旦创建后,其大小不可更改。 2. **类型安全性**...

    C#中数组Array,ArrayList,泛型List详细对比

    在C#中数组Array,ArrayList,泛型List都能够存储一组对象,但是在开发中根本不知道用哪个性能最高,下面我们慢慢分析分析。 一、数组Array 数组是一个存储相同类型元素的固定大小的顺序集合。数组是用来存储数据的...

    C#数组与Arraylist

    总的来说,理解和运用数组与ArrayList是C#程序员的基本功。在不同的应用场景下选择合适的数据结构,可以显著提高代码的效率和质量。在实际编程中,我们应根据需求选择最合适的解决方案,同时,随着技术的发展,不断...

    交换数组和差最小

    其中 `sum(array)` 表示数组 `array` 的所有元素之和。 #### 解决方案概述 本解决方案采用了一种基于遍历的方法来尝试所有可能的交换组合,并计算每次交换后两个数组之和的绝对差值。最终选择得到的最小差值对应的...

    详谈Array和ArrayList的区别与联系

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

    数组和集合对象(三) ArrayList练习

    与固定大小的数组不同,ArrayList提供了更多的灵活性,适合于需要频繁增删元素的情况。 ArrayList主要特性包括: 1. 动态扩展:ArrayList的容量会根据需要自动增长,无需预先指定长度。 2. 强类型转换:由于...

    c# 数组与集合(ArrayList)游戏开发高级使用举例

    本篇主要探讨C#数组和ArrayList在游戏开发中的高级使用技巧。 首先,数组是C#中最基础的数据结构之一。它是一个存储相同类型元素的集合,这些元素在内存中是连续存储的。数组的优势在于其访问速度快速,可以通过...

    Java Array与ArrayList区别详解

    - 对象数组和基本类型数组的主要区别在于存储方式:对象数组存储的是对象引用,基本类型数组存储的是实际的值。 5. **作为函数返回值**: - 由于Array是对象,所以可以作为函数的返回值。 6. **容器与基本类型**...

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

    Array是最基本的数组类型,而ArrayList是Java集合框架的一部分,属于动态数组。本教程由程谱CodeRecipe提供,旨在帮助已经掌握了Java基础的初学者深入理解这两种数据结构,并在实际编程中灵活运用。 首先,我们来...

    12道不错的数组例题

    数组是编程语言中基础且重要的数据结构之一,对于初级JAVA学习者来说,理解和掌握数组的用法至关重要。这里我们有12道精选的数组例题,它们可以帮助你深入理解Java中的数组概念及其应用。 1. **数组定义与初始化**...

    数组类模版及调用 arraylist

    二、ArrayList与Array的区别 ArrayList是.NET框架中的一种动态数组,它继承自ICollection和IList接口,提供了比普通数组更丰富的功能。与自定义的模板类`Array<T>`相比,ArrayList有以下特点: 1. 动态增长:...

    C# 中 Array和 ArrayList详解及区别

    C# 中 Array和 ArrayList详解及区别 一、Array 的用法 type[] typename=new type[size];  或者  type[] typename=new type[]{ };  Array类型的变量在声明的同时必须进行实例化(如果初始化至少得初始化数组...

    C#中的数组与集合类,vusual studio 2008教程

    .NET Framework 提供了多种集合类,包括但不限于 List、Array、ArrayList、Dictionary, TValue> 和 Stack<T> 等。 - **List**: 动态数组,可以动态添加和删除元素。 - **Array**: 类似于数组,但在.NET Framework中...

    C_Array Array数组

    尽管ArrayList可以存储任何类型的对象,但与泛型相比,它在类型安全和性能上有所欠缺。泛型的引入解决了这些问题,泛型允许在编译时指定类型,从而提供了类型安全,同时减少了不必要的类型转换和提高了运行时性能。...

    c#数据结构之array,arraylist,hashtable,dictionary

    C#中有多种数据结构可以用来存储和管理数据,今天我们将讨论四种常用的数据结构:Array、ArrayList、Hashtable和Dictionary。这些数据结构都是_Collections_命名空间的一部分,提供了不同的方式来存储和检索数据。 ...

    在Java中怎样把数组转换为ArrayList?

     这个问题是”在Java中怎样把数组转换为ArrayList?”  Element[] array = {new Element(1),new Element(2),new Element(3)};  1.流行也是被多人接受的答案  普遍也是被多人接受的答案如下:  ArrayList...

Global site tag (gtag.js) - Google Analytics