《JAVA编程思想》学习笔记:第11章(持有对象)

第十一章、持有对象

​​​​​​Java容器架构图:

11.1 迭代器(Iterator)

Iterator迭代器:使得客户端程序员不必知道或关心容器类的底层结构。

ListIterator:只能用于各种List类容器的访问。ListIterator可以双向移动,而Iteraotr只能向前移动。

11.2 List

ArrayList&LinkedList:都可自动扩容。

ArrayList:底层是数组结构,即连续存储空间,因可自动扩容,所以可以把ArrayList当作“可自动扩充自身尺寸的数组”看待。

优点:随机读取元素快; 缺点:在列表中间插入&删除数据慢;

LinkedList:是链表结构。

优点:在列表中间插入&删除数据快;缺点:随机读取元素慢(链表结构特征,需要指针遍历);

SparseList:Android提供的容器,优点:

CopeOnArrayList: 支持并发,用于多线程机制。

11.2.1 Stack(LIFO)

LinkdedList:具有能够直接实现栈(Stack)的所有功能的方法,因此可以直接将LinkedList作为栈使用。

11.2.2 Queue(FIFO)

LinkdedList:也提供了支持队列(Queue)行为的方法,并且实现了Queue接口,所以也可以用作Queue。

PriorityQueue:Java SE1.5新增容器,支持先弹出优先级高的元素(可实现Comparator接口)。

11.3 Set

不保存重复元素,包含下列容器:

HashSet:使用散列函数? 优点:可快速查找元素(WHY??:)

TreeSet:元素存储在红-黑树中

LinkedHashSet:散列+链表 优点:快速查找+ 插入|删除 元素 场景下的效率。

EnumSet:

CopeOnWriteArraySet: 支持并发,用于多线程机制。

11.4 Map

K-V映射表,将对象映射到其他对象的能力是一种解决编程问题的杀手锏。

HashMap:优点:快速访问元素

TreeMap: 优点:保持“Key”排序(??)

LinkedHashMap:散列(快速访问元素)+链表(插入|删除元素性能优)

EnumMap:

ConcurrentHashMap:支持并发,支持多线程场景;

WeakHashMap:弱引用的持有对象,利于GC回收,避免内存泄露?

11.5 Collection 和 Iterator

Collection:在Java中,Collection是描述所有序列容器的共性的根接口,它可能会被认为是一个“附属接口”,即因为要表示其他若干个接口的共性而出现的接口。而在标准C++类库中并没有其容器的任何公共基类。

Iterator:容器之间的所有共性都是通过迭代器达成的。Java将两种方法绑定到了一起,因为实现Collection就意味着需要提供iterator()方法。

11.5.1 Foreach与迭代器

foreach语法用于任何实现了Iterable接口的类。

Collection接口扩展了Iterable接口,所以所有Collection对象都适用foreach语法。

11.5.2 选择策略

a. Java容器:建议针对Collection接口编程,可for-each;

b. 自定义容器:建议实现Iterator,可实现迭代(若自行实现Collection,逻辑较复杂 )。

11.6 容器的元素类型(支持泛型)

11.6.1 支持泛型

a. 容器&持有对象的类型之前解耦,可支持任意类型的数据。

b. 类型编译期检测:有了泛型,容器就可以指定并检查它们所持有对象的类型;

11.6.2 持有基本数据类型(自动装箱&拆箱机制)

a. 在Java中,任何基本类型都不能作为类型参数。因此不能创建ArrayList<int> 或 HashMap<int, int>之类的东西。

b. 自动装箱&拆箱机制,实现可以持有基本数据类型:利用自动包装机制和基本类型的包装器来解决,自动包装机制将自动地实现int 到 Integer的双向转换,

11.7 过时容器(废弃)

Vector /HashTable / Stack : (WHY?? 已有替代的容器)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352