zoukankan      html  css  js  c++  java
  • 集合的相关问题

    (1)集合与数组的比较
    数组不是面向对象的,存在明显的缺陷,集合弥补了数组的一些缺点,比数组更灵活更实用,可大大提高软件的开发效率,而且不同的集合框架类可适用不同场合。具体如下:
    1:数组能存放基本数据类型和对象,而集合类中只能存放对象。
    2:数组容量固定无法动态改变,集合类容量动态改变。
    3:数组无法判断其中实际存有多少元素,length只告诉了数组的容量,而集合的size()可以确切知道元素的个数
    4:集合有多种实现方式和不同适用场合,不像数组仅采用顺序表方式
    5:集合以类的形式存在,具有封装、继承、多态等类的特性,通过简单的方法和属性即可实现各种复杂操作,大大提高了软件的开发效率
    (2)Collection和Collections的区别
    Collection是Java提供的集合接口,存储一组不唯 一,无序的对象。它有两个子接口List和Set。
    Java还有一个Collections类,专门用来操作集合类,它提供了一系列的静态方法实现对各种集合的搜索、排序、线程安全化等操作。
    (3)ArrayList和LinkedList的联系和区别
    ArrayList实现了长度可变的数组,在内存中分配连续空间。遍历元素和随机访问元素效率比较高。
    LinkedList采用链表存储方式。插入、删除元素效率比较高。
    (4)Vector和ArrayList的联系和区别
    实现原理相同,功能相同,都是长度可变的数组结构,很多时候可以互用,底层数据结构相同,都是Object类型的数组。
    两者的主要区别如下
    Vector是早期的JDK类,ArrayList是替代Vector的新类
    Vector线程安全,ArrayList重速度轻安全,线程非安全
    长度需要增长时,Vector默认增长一倍,ArrayList增长50% (0.5+1)
    Vector是在调用构造方法时,直接初始化容量为10,ArrayList是在第一次调用添加方法时,初始化容量为10。
    (5)HashMap和Hashtable的联系和区别
    实现原理相同,功能相同,底层都是哈希表结构,查询速度快,在很多情况下可以互用
    两者的主要区别如下
    Hashtable是早期的JDK提供的类,HashMap是新版的JDK提供的类
    Hashtable继承Dictionary类,实现Map接口
    ,HashMap继承了AbstractMap,实现Map接口.
    Hashtable是线程安全,HashMap线程非安全
    Hashtable不允许null 键和值,,HashMap允许null值,但是null作为key只能有一个。

  • 相关阅读:
    mysql忘记密码怎么办?
    简单Ztree的实现————不连接数据库版
    正则那些事
    牛逼的OSQL----大数据导入
    从数据库导出数据
    瀑布流动态加载图片
    MVC中使用Ajax提交数据 Jquery Ajax方法传值到action
    励志经典,持续收集ing....
    看世界新闻网的简单实现
    TestList汇总
  • 原文地址:https://www.cnblogs.com/cn-boya/p/10861465.html
Copyright © 2011-2022 走看看