精华内容
下载资源
问答
  • 首先来看看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

     

     

     

    展开全文
  • ArrayList和Array区别

    2020-01-08 11:06:45
    1)精辟阐述: 可以将 ArrayList想象成一...基于效率类型检验,应尽可能使用Array,无法确定数组大小时才使用ArrayList! 不过当你试着解决更一般化的问题时,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等。

    展开全文
  • 1)精辟阐述: 可以将 ArrayList想象成一种“会自动扩增容量的Array...基于效率类型检验,应尽可能使用Array,无法确定数组大小时才使用ArrayList! 不过当你试着解决更一般化的问题时,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和数组之间的转换?

    展开全文
  • ArrayList Vector 的区别是什么? 线程安全:Vector 使用了 Synchronized 来实现线程同步,是线程安全的,而 ArrayList 是非线程安全的。...Array ArrayList 有何区别Array 可以存储基本数据类型对象,Array
  • C# Array和ArrayList区别 C# Array和ArrayList区别 一,C# array数组的用法范例: type[] typename=new type[size]; 如int[] a=new int[2];string[] str=new string[5]; 实事上我们平常是...
  • ArrayList &...LinkedList :以链表方式来实现List接口进行插入删除等操作效率更高,适合用来实现Stack(堆栈)Queue(队列)(链表特性:插入删除效率高) 注: LinkedList的特有方法(本身定义...
  • 主要介绍了C# 中 Array和 ArrayList详解及区别的相关资料,需要的朋友可以参考下
  • Array ArrayList 有何区别: Array 可以存储基本数据类型对象,ArrayList 只能存储对象。 Array 是指定固定大小的,而 ArrayList 大小是自动扩展的。 Array 内置方法没有 ArrayList 多,比如 addAll、remove...
  • C# Array和ArrayList,List区别
  • 昨天去了一个java的实习面试,发现有好多java最基础的数据结构对于博主来说反而感到陌生,在面试官问一些常见的例如HashMap这样的数据结构,博主能回答的头头是道,但是在问到Array和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 时...
  • Array和ArrayList有什么区别

    千次阅读 2020-06-21 09:53:11
    数组(Array)列表(ArrayList)的区别Array可以包含基本类型对象类型,ArrayList只能包含对象类型。 Array大小是固定的,ArrayList的大小是动态变化的。 ArrayList提供了更多的方法特性,比如:addAll()...
  • ArrayListArray区别概述 ArrayList 是数组的复杂版本。ArrayList 类提供在大多数 Collections 类中提供但不在 Array 类中提供的一些功能。例如: Array 的容量是固定的,而 ArrayList 的容量是根据需要...
  • ArrayList和LinkedList区别及使用场景

    万次阅读 多人点赞 2018-09-07 18:51:40
    ArrayList和LinkedList区别及使用场景 1. LinkedList和ArrayList的差别主要来自于Array和LinkedList数据结构的不同。ArrayList是基于数组实现的,LinkedList是基于双链表实现的。另外LinkedList类不仅是List接口的...
  • Array:可以容纳基本类型对象、可以指定大小、没有像ArrayList那么全面的功能例如addAll()、removeAll() ArrayList:只能容纳对象不能容纳基本类型、大小固定、相比于Array方法更多更全面
  • Array和ArrayList区别

    2021-03-27 10:27:26
    Araay可以包含基本类型对象类型,ArrayList只能包含对象类型 3.使用 Array 中,只能一次获取或设置一个元素值 ArrayList 提供了添加、插入或移除 某一范围元素的方法 4.效率 因为ArrayList是在Array的基础上做了...
  • 028 Array ArrayList 有何区别? 答: 根本区别Array 是数组;ArrayList 是集合 存储内容比较: Array可以包含基本类型对象类型,ArrayList只能包含对象类型。 空间大小比较: array 是数组,arraylist 是...
  • C# 中 Array和 ArrayList详解及区别一、Array 的用法type[] typename=new type[size];或者type[] typename=new type[]{ };Array类型的变量在声明的同时必须进行实例化(如果初始化至少得初始化数组的大小)平常我们int...
  • Array数组可以包含基本类型对象类型, ArrayList却只能包含对象类型。 但是需要注意的是:Array数组在存放的时候一定是同种类型的元素。ArrayList就不一定了,因为ArrayList可以存储Object。 空间大小比较: 它的...
  • Array和ArrayList区别

    2015-05-20 22:46:40
    Array和ArrayList区别
  • 1)精辟阐述:可以将...3)建议:基于效率类型检验,应尽可能使用Array,无法确定数组大小时才使用ArrayList!不过当你试着解决更一般化的问题时,Array的功能就可能过于受限。4)Java中一切皆对象,Array也是...

空空如也

空空如也

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

arraylist和array区别