精华内容
下载资源
问答
  • ArrayList和Array的区别

    2020-01-08 11:06:45
    1)精辟阐述: 可以将 ArrayList想象成一种“会自动扩增容量的Array”。 2)Array([]):最高效;但是其容量固定且无法...不过当你试着解决更一般化的问题时,Array的功能就可能过于受限。 4)Java中一切皆对象,...

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

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

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

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

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

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

    5)Array可做为函数返回值,因为它本身是对象的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中做删除等操作的原因(因为此时应该使用链表)。

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

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

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

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

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

    展开全文
  • 首先来看看ArrayList和Array的区别 Array在java里为数组,而ArrayList则是列表。 Array的大小是固定的,而ArrayList则是可变的是动态变化的,ArrayList提供了更多的方法。   最后我们来讨论ArrayList与数组的...

    首先来看看ArrayList和Array的区别

    Array在java里为数组,而ArrayList则是列表。

    Array的大小是固定的,而ArrayList则是可变的是动态变化的,ArrayList提供了更多的方法。

     

    最后我们来讨论ArrayList与数组的差别,以及ArrayList的效率问题
               (1)ArrayList是Array的复杂版本
    ArrayList内部封装了一个Object类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList的许多方法,如Index、IndexOf、Contains、Sort等都是在内部数组的基础上直接调用Array的对应方法。

    (2)内部的Object类型的影响

           对于一般的引用类型来说,这部分的影响不是很大,但是对于值类型来说,往ArrayList里面添加和修改元素,都会引起装箱和拆箱的操作,频繁的操作可能会影响一部分效率。

     

    但是恰恰对于大多数人,多数的应用都是使用值类型的数组。
    消除这个影响是没有办法的,除非你不用它,否则就要承担一部分的效率损失,不过这部分的损失不会很大。
                  (3)数组扩容
    这是对ArrayList效率影响比较大的一个因素。
    每当执行Add、AddRange、Insert、InsertRange等添加元素的方法,都会检查内部数组的容量是否不够了,如果是,它就会以当前容量的两倍来重新构建一个数组,将旧元素Copy到新数组中,然后丢弃旧数组,在这个临界点的扩容操作,应该来说是比较影响效率的。
         例1:比如,一个可能有200个元素的数据动态添加到一个以默认16个元素大小创建的ArrayList中,将会经过:
    16*2*2*2*2 = 256

     

    四次的扩容才会满足最终的要求。

    如何去使用ArrayList

    1.

    //创建列表,并添加a b
    		ArrayList arraylist=new ArrayList();
    		arraylist.add("a");
    		arraylist.add("b");
    		
    		System.out.println(arraylist);

    2.

    //在1的基础上插入一个c 位于a 与b 之间
    		arraylist.add(1,"c");
    		System.out.println(arraylist);
    

    3.

    //创建一个新的arrarylist 并在上面的基础上添加到新的arrarylist
    		ArrayList list=new ArrayList();
    		list.add("d");
    		list.add(arraylist.clone());		
    		System.out.println("新"+list);
    

    4.

    //删除第一个字符
    		arraylist.remove(0);
    		//或者	arraylist.remove("a");
    		System.out.println(arraylist);

    5.

    //按照集合删除多条数据
    		arraylist.removeAll(list);
    		
    		

    6.

    //修改指定位置的元素 修改第一个元素为q
    		arraylist.set(0, "q");
    		

    7.

    //获取列表第一个的元素
    		arraylist.get(0);

     

     

     

     

     

     

    参考文章 http://www.cnblogs.com/rickie/articles/67978.html

     

     

     

    展开全文
  • 1)精辟阐述: 可以将 ArrayList想象成一种“会自动扩增容量的Array”。 2)Array([]):最高效;但是其容量固定且无法动态改变;...不过当你试着解决更一般化的问题时,Array的功能就可能过于受限

    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容器:11、ArrayList和Array的区别

    ArrayList和Array(数组)的区别?

    (1)自动扩容
    数组是固定容量的,ArrayList底层是可以自动扩容的数组。可以理解为ArrayList是可以自动扩容的数组。

    (2)包含的类型
    数组可以包含基本类型和对象类型,ArrayList只能包含对象类型。

    (3)初始化容量
    数组在声明时,需要初始化容量大小,而ArrayList不必。

    (4)随意插入或删除
    Array不能够随意添加和删除其中的项,而ArrayList可以在任意位置插入和删除项。

    相关推荐:
    如何实现List和数组之间的转换?

    展开全文
  • ArrayListArray的区别概述 ArrayList 是数组的复杂版本。ArrayList 类提供在大多数 Collections 类中提供但不在 Array 类中提供的一些功能。例如: Array 的容量是固定的,而 ArrayList 的容量是根据需要...
  • ArrayList 是数组复杂版本。ArrayList 类提供在大多数 Collections 类...如果更改了 ArrayList.Capacity 属性值,则自动进行内存重新分配元素复制。 ArrayList 提供添加、插入或移除某一范围元素方法。在 A...
  • ArrayList 是数组复杂版本。ArrayList 类提供在大多数 Collections 类...如果更改了 ArrayList.Capacity 属性值,则自动进行内存重新分配元素复制。 ArrayList 提供添加、插入或移除某一范围元素方法。在 ...
  • Array ArrayList 的区别

    千次阅读 2019-05-06 11:38:33
    Array ArrayList 有何区别Array 即数组,声明方式可以如下: int[] array = new int[3]; int array [] = new int[3]; int[] array = {1, 2, 3}; int[] array = new int[]{1, 2, 3}; 定义一个 Array 时...
  • ArrayList 是数组复杂版本。ArrayList 类提供在大多数 Collections 类中...如果更改了 ArrayList.Capacity 属性值,则自动进行内存重新分配元素复制。 ArrayList 提供添加、插入或移除某一范围元素方法。在 Arr
  • C# Array和ArrayList区别 C# Array和ArrayList区别 一,C# array数组用法范例: type[] typename=new type[size]; 如int[] a=new int[2];string[] str=new string[5]; 实事上我们平常是...
  • Array和ArrayList的区别

    2015-05-20 22:46:40
    Array和ArrayList的区别
  • ArrayList Vector 的区别是什么? 线程安全:Vector 使用了 Synchronized 来实现线程同步,是线程安全的,而 ArrayList 是非线程安全的。 性能:ArrayList 在性能方面要优于 Vector。 扩容:ArrayList Vector ...
  • ArrayList 数组列表 LinkedList 链表 Array 数组 set集合 ArrayDeque 双端队列 map 图 SequentialList 顺序表 Queue 队列package NEW_DATE_SEQUENCE_PACKAGE;import java.util.LinkedList; import java.util....
  • Array 类提供了各种用于数组属性方法。 属性如: IsReadOnly数组只读。Length数组长度。 方法常用如下: 1 Clear 根据元素类型,设置数组中某个范围元素为零、为 false 或者为 null。 2 Copy(Array, Array...
  • Array ArrayList 有何区别: Array 可以存储基本数据类型对象,ArrayList 只能存储对象。 Array 是指定固定大小,而 ArrayList 大小是自动扩展Array 内置方法没有 ArrayList 多,比如 addAll、remove...
  • ArrayList和LinkedList的区别 1、数据结构不同 ArrayList是Array(动态数组)的数据结构,LinkedList是Link(链表)的数据结构。 2、效率不同 当随机访问List(get和set操作)时,ArrayList比LinkedList的效率更高,因为...
  • Array和ArrayList区别

    2019-10-16 22:38:48
    Array的大小是固定的,而ArrayList的大小是可以动态变化的。 简单来说,ArrayList是一个长度可以自动增长的Array 其实上面一句话就道尽了两者最核心的区别 长度:Array长度固定,ArrayList可以动态扩容 效率:效率...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 899
精华内容 359
关键字:

arraylist和array的区别