- 浏览: 252232 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
liuweihug:
这个博客不错。都是干货。Jquery+asp.net 后台数据 ...
jquery ajax 中文乱码 -
龙晓舟:
博主真不错!请问,德比的酒店系统有单体店的吗?支持多语言吗?那 ...
我的作品 -
勒布朗-小明:
抽象工厂模式 的例子在哪呢??
Java工厂模式 factory -
llpuya:
hh
Java工厂模式 factory -
phpxiaoxin:
yuhe 写道git init --bare 执行不成功呢?错 ...
git at redhat5
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)。
发表评论
-
关于ThreadLocal
2012-12-31 18:45 1177关于ThreadLocal 文章介绍了ThreadLo ... -
java 关于内存溢出的相关知识
2012-12-27 16:31 1223http://developer.51cto.c ... -
一次webservice的旅行
2012-12-25 16:19 0最近我们有这样一个需求,就是发布一个与别人一模一样的webse ... -
scala 相关内容整理
2012-07-11 21:18 1441首先是scala 的环境搭建 :鉴客 搭建基于 IDEA 的 ... -
Hibernate DetachedCriteria 一对多查询
2011-05-31 10:50 2856DetachedCriteria detachedCrit ... -
cxf spring 发布 webservice 供 .net使用
2010-12-31 21:23 2484cxf 是 xfire 的替代工具 ... -
spring proxyTargetClass 动态代理
2010-12-13 20:25 3397今天做两个项目的集成,主项目单独跑没问题,子项目单独跑没问题, ... -
spring事务无异常回滚 [spring rollback without exception]
2010-12-13 16:54 2382在使用spring的时候通常我们可以通过抛出异常的方式完成回滚 ... -
都是spring若的祸-spring从使用到原理
2010-06-07 10:46 0spring2.5中文文档 http://arro ... -
从ant到maven -- maven pom例子(初级)
2010-04-20 14:31 7462最近将项目从ant改成了maven,改的过程中,遇到一些问题, ... -
MAVEN2实用指南, maven2权威指南中英
2010-04-06 11:06 2102maven2权威指南中英 :http://xizhenyin. ... -
Java 回调(callback) 内部类(innerclass)
2009-12-22 21:01 1608/** * 动物 */ public class A ... -
Struts2
2009-11-03 17:30 1355struts2 中 OGNL表达式的使用 http ... -
HttpInvoker 远程调用
2009-10-20 19:35 1922HttpInvoker 远程调用实例 http://www. ... -
java 基础概念知识
2009-10-20 14:55 1863java 泛型 http://baike.baidu.com ... -
spring BeanFactory 实现类的getBean方法
2009-10-10 10:59 3131原文:http://blog.163.com/ka ... -
连接池
2009-09-09 22:35 1694转自http://baike.baidu.com/view/1 ... -
guice:Guice和Spring框架的区别
2009-09-02 17:55 1479转自:http://www.crazycoder.cn/ :h ... -
第一次java web面试总结
2009-07-31 13:12 4534公司为某大公司济南的 ... -
关于tomcate配置的一些东西
2009-07-13 10:51 1335乱码问题,这里说的是url乱码的解决方式可以通过配置tomca ...
相关推荐
本文将基于标题"java面试基础"以及提供的标签"源码"和"工具",结合压缩包中的文档名称,对Java面试中的核心知识点进行深入探讨。 首先,Java语言的基础知识是面试者必须掌握的。这包括但不限于变量、数据类型、控制...
java面试基础知识点总结
Java面试笔记 225道Java面试题JAVA面试基础知识点总结Java数据结构题 JAVA笔试面试WORD资料汇总(19个): 2014年最新Java笔试题及答案.docx 225道Java面试题 学会了Java面试随你问.docx Ant和Maven的作用是什么?两者...
介绍Java求职面试过程过程中的相关知识点,分为java基础,web,框架等基础知识
【JAVA面试基础题软件】是一款专门针对JAVA程序员面试设计的学习工具,它包含了多套精心整理的JAVA面试基础题目,旨在帮助用户巩固JAVA编程基础知识,并在面试前进行有效的强化练习。这款软件涵盖了JAVA语言的核心...
"Java面试基础知识" Java 面试基础知识是 Java 开发者在面试时需要了解的基础知识点。以下是 Java 面试基础知识的重要知识点: 1. Java 的接口和 C++的虚类的雷同和不合处 Java 的接口和 C++ 的虚类有相似之处,...
以上知识点在"Java面试基础机试题"中可能都有所体现,通过解答这些题目,可以全面检验并提升Java开发者的基础技能和问题解决能力。在准备面试时,不仅需要理解这些概念,还要能够灵活运用,解决实际问题。
Java面试基础知识是每个Java开发者在求职过程中必须掌握的关键领域。以下是一些可能被面试官问到的核心知识点,以及应聘者需要准备的内容。 1. **Java基础语法**:这是所有Java面试的基础,包括变量、数据类型...
"达内javaPPT课件+java面试基础复习" 提供了一个全面学习和准备Java面试的资源包。这个资料集主要关注Java的基础知识,对于求职者或者希望提升Java技能的人来说,是一个非常宝贵的学习工具。 首先,我们来探讨Java...
Java面试基础题涵盖了许多核心Java概念,这些都是面试者在准备Java面试时必须掌握的关键知识点。 首先,面向对象的特征是Java编程的基础。这包括抽象、继承、封装和多态性。抽象关注的是忽略无关的细节,专注于核心...
【JAVA面试基础题库】 在Java面试中,掌握基础知识至关重要,因为面试官通常会通过基础问题来评估候选人的编程能力和对语言的理解。以下是一些Java面试中常见的知识点: 1. **变量与数据类型** - Java中的变量...
JAVA 面试基础知识点总结 JAVA 是一种广泛使用的编程语言,具有平台无关性、安全性、面向对象、分布式和健壮性等特点。在面试中,了解 JAVA 的基础知识点非常重要。本文将从 JAVA 的历史、版本、特点、开发环境、...
Java面试基础篇+并发篇,这是我总结出来非常全面的Java面试的基础篇和并发编程方面的面试题
java面试基础记录_javaBaseView
java面试基础知识点复习,按这个复试,必定助你面试上心仪的公司。
java面试基础题视频讲解,讲解基础原理,补充java基础知识
什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”
为了在Java面试中脱颖而出,了解并掌握基础的Java知识至关重要。本资料集旨在帮助那些希望巩固Java基础知识或为面试做准备的读者。以下是一些核心的Java知识点详解: 1. **Java语法基础**:包括变量、数据类型...