`
phpxiaoxin
  • 浏览: 252936 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java 面试基础

    博客分类:
  • java
阅读更多

ArrayList LinkedList 的区别

      对于处理一系列数据项,Java提供了两个类ArrayList和LinkedList.

 

      ArrayList的内部实现是基于内部数组Object[],所以从概念上讲,它更象数组,但LinkedList的内部实现是基于一组连接的记录,所以,它更象一个链表结构,所以,它们在性能上有很大的差别。
      从上面的分析可知,在ArrayList的前面或中间插入数据时,你必须将其后的所有数据相应的后移,这样必然要花费较多时间,所以,当你的操作是在一列 数据的后面添加数据而不是在前面或中间,并且需要随机地访问其中的元素时,使用ArrayList会提供比较好的性能
      而访问链表中的某个元素时,就必须从链表的一端开始沿着连接方向一个一个元素地去查找,直到找到所需的元素为止,所以,当你的操作是在一列数据的前面或中间添加或删除数据,并且按照顺序访问其中的元素时,就应该使用LinkedList了。
       如果在编程中,1,2两种情形交替出现,这时,你可以考虑使用List这样的通用接口,而不用关心具体的实现,在具体的情形下,它的性能由具体的实现来保证。
       配置集合类的初始大小
       在Java集合框架中的大部分类的大小是可以随着元素个数的增加而相应的增加的,我们似乎不用关心它的初始大小,但如果我们考虑类的性能问题时,就一定要考虑尽可能地设置好集合对象的初始大小,这将大大提高代码的性能。
      比如,Hashtable缺省的初始大小为101,载入因子为0.75,即如果其中的元素个数超过75个,它就必须增加大小并重新组织元素,所以,如果你 知道在创建一个新的Hashtable对象时就知道元素的确切数目如为110,那么,就应将其初始大小设为110/0.75=148,这样,就可以避免重 新组织内存并增加大小。

 

 

HashMap和Hashtable的区别

 

1 HashMap不是线程安全的

 

            hastmap是一个接口 是map接口的子接口,是将键映射到值的对象,其中键和值都是对象,并且不能包含重复键,但可以包含重复值。HashMap允许null key和null value,而hashtable不允许。

 

2   HashTable是线程安全的一个Collection。

 

HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。
HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因为contains方法容易让人引起误解。
Hashtable继承自Dictionary类,而HashMap是Java1.2引进的Map interface的一个实现。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap 就必须为之提供外同步。
Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异。

 

public static void main(String args[])
{
HashTable h=new HashTable();
h.put("用户1",new Integer(90));
h.put("用户2",new Integer(50));
h.put("用户3",new Integer(60));
h.put("用户4",new Integer(70));
h.put("用户5",new Integer(80));
Enumeration e=h.elements();
while(e.hasMoreElements()){
System.out.println(e.nextElement());
}

 

map 的方法:

 

clear()从 Map 中删除所有映射

 

remove(Object key)从 Map 中删除键和关联的值

 

 

       put(Object key, Object value)将指定值与指定键相关联

get(Object key)返回与指定键关联的值

 

 

containsKey(Object key)如果 Map 包含指定键的映射,则返回 true

 

 

 

 

containsValue(Object value)如果此 Map 将一个或多个键映射到指定值,则返回 true

 

isEmpty()如果 Map 不包含键-值映射,则返回 true size()返回 Map 中的键-值映射的数目


list map set

 

 

这些都代表了 Java 中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。

 

 

 


 


有序否


允许元素重复否


Collection




List




Set


AbstractSet




HashSet


TreeSet


是(用二叉树排序)


Map


AbstractMap



使用 key-value 来映射和存储数据, Key 必须惟一, value 可以重复


HashMap


TreeMap


是(用二叉树排序)

 

 

 

 

 

http://tb.blog.csdn.net/TrackBack.aspx?PostId=584112

 

 

 

List 接口对Collection进行了简单的扩充,它的具体实现类常用的有ArrayList和LinkedList。你可以将任何东西放到一个List容器 中,并在需要时从中取出。ArrayList从其命名中可以看出它是一种类似数组的形式进行存储,因此它的随机访问速度极快,而LinkedList的内 部实现是链表,它适合于在链表中间需要频繁进行插入和删除操作。在具体应用时可以根据需要自由选择。前面说的Iterator只能对容器进行向前遍历,而 ListIterator则继承了Iterator的思想,并提供了对List进行双向遍历的方法。

Set接口也是 Collection的一种扩展,而与List不同的时,在Set中的对象元素不能重复,也就是说你不能把同样的东西两次放入同一个Set容器中。它的常 用具体实现有HashSet和TreeSet类。HashSet能快速定位一个元素,但是你放到HashSet中的对象需要实现hashCode()方 法,它使用了前面说过的哈希码的算法。而TreeSet则将放入其中的元素按序存放,这就要求你放入其中的对象是可排序的,这就用到了集合框架提供的另外 两个实用类Comparable和Comparator。一个类是可排序的,它就应该实现Comparable接口。有时多个类具有相同的排序算法,那就 不需要在每分别重复定义相同的排序算法,只要实现Comparator接口即可。集合框架中还有两个很实用的公用类:Collections和 Arrays。Collections提供了对一个Collection容器进行诸如排序、复制、查找和填充等一些非常有用的方法,Arrays则是对一 个数组进行类似的操作。


            Map是一种把键对象和值对象进行关联的容器,而一个值对象又可以是一个Map,依次类推,这样就可形成一个多级映射。对于键对象来说,像Set一样,一 个Map容器中的键对象不允许重复,这是为了保持查找结果的一致性;如果有两个键对象一样,那你想得到那个键对象所对应的值对象时就有问题了,可能你得到 的并不是你想的那个值对象,结果会造成混乱,所以键的唯一性很重要,也是符合集合的性质的。当然在使用过程中,某个键所对应的值对象可能会发生变化,这时 会按照最后一次修改的值对象与键对应。对于值对象则没有唯一性的要求。你可以将任意多个键都映射到一个值对象上,这不会发生任何问题(不过对你的使用却可 能会造成不便,你不知道你得到的到底是那一个键所对应的值对象)。Map有两种比较常用的实现: HashMap和TreeMap。HashMap也用到了哈希码的算法,以便快速查找一个键,TreeMap则是对键按序存放,因此它便有一些扩展的方 法,比如firstKey(),lastKey()等,你还可以从TreeMap中指定一个范围以取得其子Map。键和值的关联很简单,用pub (Object key,Object value)方法即可将一个键与一个值对象相关联。用get(Object key)可得到与此key对象所对应的值对象。

 

转自:http://blog.csdn.net/ago52030/archive/2008/04/12/2287041.aspx

 

 

关于链表

 

 

1、链接存储方法
     链接方式存储的线性表简称为链表(Linked List)。
     链表的具体存储表示为:
  ① 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的,也可以是不连续的)
  ② 链表中结点的逻辑次序和物理次序不一定相同。为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link))
注意:
  链式存储是最常用的存储方式之一,它不仅可用来表示线性表,而且可用来表示各种非线性的数据结构。

2、链表的结点结构
  ┌——┬——┐
  │data│next│
  └——┴——┘ 
       data域--存放结点值的数据域
       next域--存放结点的直接后继的地址(位置)的指针域(链域)
注意:
     ①链表通过每个结点的链域将线性表的n个结点按其逻辑顺序链接在一起的。
     ②每个结点只有一个链域的链表称为单链表(Single Linked List)。

分享到:
评论

相关推荐

    java面试基础

    本文将基于标题"java面试基础"以及提供的标签"源码"和"工具",结合压缩包中的文档名称,对Java面试中的核心知识点进行深入探讨。 首先,Java语言的基础知识是面试者必须掌握的。这包括但不限于变量、数据类型、控制...

    java面试基础知识点总结

    java面试基础知识点总结

    Java面试笔记 225道Java面试题JAVA面试基础知识点总结Java数据结构题笔试WORD资料汇总(19个).zip

    Java面试笔记 225道Java面试题JAVA面试基础知识点总结Java数据结构题 JAVA笔试面试WORD资料汇总(19个): 2014年最新Java笔试题及答案.docx 225道Java面试题 学会了Java面试随你问.docx Ant和Maven的作用是什么?两者...

    java面试基础知识点

    介绍Java求职面试过程过程中的相关知识点,分为java基础,web,框架等基础知识

    JAVA面试基础题软件

    【JAVA面试基础题软件】是一款专门针对JAVA程序员面试设计的学习工具,它包含了多套精心整理的JAVA面试基础题目,旨在帮助用户巩固JAVA编程基础知识,并在面试前进行有效的强化练习。这款软件涵盖了JAVA语言的核心...

    Java面试基础知识.doc

    "Java面试基础知识" Java 面试基础知识是 Java 开发者在面试时需要了解的基础知识点。以下是 Java 面试基础知识的重要知识点: 1. Java 的接口和 C++的虚类的雷同和不合处 Java 的接口和 C++ 的虚类有相似之处,...

    java面试基础机试题

    以上知识点在"Java面试基础机试题"中可能都有所体现,通过解答这些题目,可以全面检验并提升Java开发者的基础技能和问题解决能力。在准备面试时,不仅需要理解这些概念,还要能够灵活运用,解决实际问题。

    java面试基础知识

    Java面试基础知识是每个Java开发者在求职过程中必须掌握的关键领域。以下是一些可能被面试官问到的核心知识点,以及应聘者需要准备的内容。 1. **Java基础语法**:这是所有Java面试的基础,包括变量、数据类型...

    达内javaPPT课件+java面试基础复习

    "达内javaPPT课件+java面试基础复习" 提供了一个全面学习和准备Java面试的资源包。这个资料集主要关注Java的基础知识,对于求职者或者希望提升Java技能的人来说,是一个非常宝贵的学习工具。 首先,我们来探讨Java...

    Java面试基础题

    Java面试基础题涵盖了许多核心Java概念,这些都是面试者在准备Java面试时必须掌握的关键知识点。 首先,面向对象的特征是Java编程的基础。这包括抽象、继承、封装和多态性。抽象关注的是忽略无关的细节,专注于核心...

    JAVA面试基础知识点总结.docx

    JAVA 面试基础知识点总结 JAVA 是一种广泛使用的编程语言,具有平台无关性、安全性、面向对象、分布式和健壮性等特点。在面试中,了解 JAVA 的基础知识点非常重要。本文将从 JAVA 的历史、版本、特点、开发环境、...

    Java面试基础篇+并发篇,这是我总结出来非常全面的Java面试的基础篇和并发编程方面的面试题

    Java面试基础篇+并发篇,这是我总结出来非常全面的Java面试的基础篇和并发编程方面的面试题

    java面试基础记录_javaBaseView.zip

    java面试基础记录_javaBaseView

    java面试基础知识点复习

    java面试基础知识点复习,按这个复试,必定助你面试上心仪的公司。

    java面试题视频讲解

    java面试基础题视频讲解,讲解基础原理,补充java基础知识

    java面试基础+高级

    什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”

    Java面试基础题,主要是Java基础,多线程

    java面试

    JAVA面试基础题

    为了在Java面试中脱颖而出,了解并掌握基础的Java知识至关重要。本资料集旨在帮助那些希望巩固Java基础知识或为面试做准备的读者。以下是一些核心的Java知识点详解: 1. **Java语法基础**:包括变量、数据类型...

Global site tag (gtag.js) - Google Analytics