TIJ——Chapter Eleven:Holding Your Objects
Java Provides a number of ways to hold objects:
- An array associates numerical indexes to objects. It holds objects of a known type so that you don't have to cast the result when you're looking up an object. It can be multidimensional, and it can hold primitives. However, its size cannot be changed once you create it.
- A Collection holds signle elements, and a Map holds associated pairs. With Java generics, you specify the type of objec to be held in the containers, so you can't put the wrong type into a container and you don't have to cast elements when you fetch them out of a container. Both Collections and Maps automatically resize themselves as you add more elements. A container won't hold primitives, but autoboxing takes care of translating primitives back and forth to the wrapper types held in the container.
- Like an array, a List also associates numerical indexed to objects—thus, arrays and Lists are ordered containers.
- Use an ArrayList if you're doing a lot of random accesses, but a LinkedList if you will be doing a lot of insertions and removals in the middle of the list.
- The behavior of Queue and Stack is provided via the LinkedList.
- A Map is a way to associate not integral values, but objects with other objects. HashMap are designed for rapid access, whereas a TreeMap keeps its keys in sorted order, and thus is not as fast as a HashMap. A LinkedHashMap keeps its elements in insertion order, but provides rapid access with hashing.
- A set only accepts one of each type of object. HashSet provide maximally fast lookups, whereas TreeSet keep the elements in sorted order. LinkedHashSet keep elements in insertion order.
- There's no need to use the legacy classes Vector, Hashtable, and Stack in new code.
It's helpful to look at a simplified diagram of the Java containers(without the abstract classes or legacy components). This only includes the interfaces and classes that you will encounter on a regular basis.

图中,用粗黑线框包围的容器(HashMap、ArrayList、LinkedList、HashSet)是我们在开发过程中要频繁使用的;虚线框表示接口,实线框表示具体的实现类;空心箭头表示某一个类实现了所指向的接口,实心箭头表示一个类(或实现某个接口的类)能生成一个指向类的对象。
- 对于容器而言,使用泛型与不使用泛型的几个重要的区别是:当往容器中放元素的时候,如果使用泛型,那么对于类型不兼容的对象,会在编译期报错;而且从容器中取出元素的时候,使用泛型则不需要类型转换,而不使用泛型则必须进行类型转换。可以看出,使用泛型可以使我们的代码更精简、健壮,同时不必记忆放入容器中元素的类型。
- The Java container library takes the idea of "holding your object" and divides it into two distinct concepts, expressed as the basic interfaces of the library:Lists promise to maintain elements in a particular sequence. The List interface adds a number of methods to Collection that allow insertion and removal of elements in the middle of a List. There are two types of List:
- Collection: a sequence of individual elements with one or more rules applied to them. A List must hold the elements in the way that they were inserted, a Set cannot have duplicate elements.
- Map: a group of key-value object pairs, allowing you to look up a value using a key. An ArrayList allows you to look up an object using a number, so in a sense it associates number to objects. A map allows you to look up an object using another object. It's also called an associative array, because it associates objects with another objects, or a dictionary, because you look up a value object using a key object just like you look up a definition using a word. Maps are powerful programming tools.
- Lists promise to maintain elements in a particular sequence. The List Interface adds a number of methods to Collection that allow insertion and removal of elements in the middle of a List. There are two types of List:
- The basic ArrayList, which excels at randomly accessing elements, but is slower when inserting and removing elements in the middle of a List.
- The LinkedList, which provides optimal sequential access, with inexpensive insertions and deletions from the middle of the List. A LinkedList is relatively slow for random access, but it has a larger feature set than the ArrayList.
- The Java Iterator can move in only one direction, There's not much you can do with an Iterator except(With an Iterator, you don't need to worry about the number of elements in the container. That's taken care of for you by hasNext() and next()):
- Ask a Collection to hand you an Iterator using a method called iterator(). That Iterator will be ready to return the first element in the sequence.
- Get the next object in the sequence with next().
- See if there are more object in the sequence with hasNext().
- Remove the last element returned by the iterator with remove().
- HashSet uses hashing for speed. The Order maintained by a HashSet is different from a TreeSet or a LinkedHashSet, since each implementation has a different way of storing elements. TreeSet keeps elements sorted into a red-black tree data structure, whereas HashSet uses the hashing fuction. LinkedHashSet also uses hashing for lookup speed, but appears to maintain elements in insertion order using a linked list.
- A foreach statement works with an array or anything Iterable, but that doesn't mean that an array is automatically an Iterable, nor is there any autoboxing that takes place:
public class ArrayIsNotIterable
{
static <T> void test(Iterable<T> ib)
{
for(T t : ib)
{
System.out.print(t + " ");
}
} public static void main(String[] args)
{
test(Arrays.asList(1, 2, 3));
String[] strings = {"A", "B", "C"}; // An array works in foreach, but it's not Iterable:
// !test(strings);
// You must explicitly convert it to Iterable:
test(Arrays.asList(strings));
}
}
/*
Output:
1 2 3 A B C
*/
TIJ——Chapter Eleven:Holding Your Objects的更多相关文章
- TIJ——Chapter One:Introduction to Objects
///:~容我对这个系列美其名曰"读书笔记",其实shi在练习英文哈:-) Introduction to Objects Object-oriented programming( ...
- TIJ——Chapter Two:Everything Is an Object
If we spoke a different language, we would perceive a somewhat different world. Ludwig Wittgenstein( ...
- TIJ——Chapter Twelve:Error Handling with Exception
Exception guidelines Use exceptions to: Handle problems at the appropriate level.(Avoid catching exc ...
- TIJ——Chapter Eight:Polymorphism
The twist |_Method-call binding Connecting a method call to a method body is called binding. When bi ...
- TIJ——Chapter Seven:Reusing Classes
Reusing Classes 有两种常用方式实现类的重用,组件(在新类中创建存在类的对象)和继承. Composition syntax Every non-primitive object has ...
- TIJ——Chapter Five:Initialization & Cleanup
Method overloading |_Distinguishing overloaded methods If the methods hava the same name, how can Ja ...
- Think Python - Chapter 15 - Classes and objects
15.1 User-defined typesWe have used many of Python’s built-in types; now we are going to define a ne ...
- Chapter 3 Introduction to Objects and Input/Output
与声明一个primitive variable不同,声明一个对象的时候,并不创建用来存储一个对象的内存空间,而是创建了一个存储该对象所在内存空间的地址. 在java里,new是一个操作符,它让系统分配 ...
- TIJ——Chapter Thirteen:Strings
String 对象是不可修改的,对于被String 重载的'+' 和'+=' 运算符来说,当你用它们来连接两个String 对象的时候,它在底层并不会对于每一次连接均生成一个String 对象,取而代 ...
随机推荐
- 各种解析漏洞获取Webshell
各种解析漏洞拿shell 一.IIS 6.0解析漏洞 IIS 6.0解析利用方法有两种1.目录解析/xx.asp/xx.jpg2.文件解析wooyun.asp;.jpg第一种,在网站下建立文件夹的名 ...
- CodeForces 103D 分块处理
题目链接:http://codeforces.com/problemset/problem/103/D 题意:给定一个长度为n的序列.然后q个询问.每个询问为(a,b),表示从序列第a项开始每b项的加 ...
- Poj2479 & Poj 2593
就是按着DP的思路来做的,结果还是想不到.T_T,行了,别玻璃心了,继续. 这道题目是求在一列数里,由两部分子段和组成的最大和.即对于连续整数组成的串 S1.S2,使 S1 + S2 的和最大. 题目 ...
- stl文件格式
http://wenku.baidu.com/view/a3ab7a26ee06eff9aef8077b.html [每个三角形面片的定义包括三角形各个定点的三维坐标及三角形面片的法矢量[三角形的法线 ...
- mysql锁 实战测试代码
存储引擎 支持的锁定 MyISAM 表级锁 MEMORY 表级锁 InnoDB 行级锁 BDB 页面锁 表级锁:开销小,加锁快:不会出现死锁:锁定粒度大,发生锁冲突的概率最高,并发度最低.行级锁:开销 ...
- assert_option()可以用来对assert()进行一些约束和控制
一.evaleval用法:eval() 函数把字符串按照 PHP 代码来计算.该字符串必须是合法的 PHP 代码,且必须以分号结尾.如果没有在代码字符串中调用 return 语句,则返回 NULL.如 ...
- H TC並沒有成為下一個摩托羅拉或諾基亞。
關於2014年第四季度,H T C在三季度財報說明中提到,“年度旗艦H T CO ne(M 8)與中端機型H T C D esire系列在競爭日趨激烈的智能手機市場保持穩定的銷售,市占率有所提升,延續 ...
- 安卓中級教程(8):pathbutton中的animation.java研究(1)
src/geniuz/myPathbutton/myAnimations.java package geniuz.myPathbutton; import java.util.ArrayList; i ...
- finnal 评论 II
新蜂团队:俄罗斯方块界面设计给人眼前一亮的感觉,很喜欢他们界面的颜色搭配.功能上实现了俄罗斯方块的基本功能,并且没有bug.最重要的是游戏有自己的创新点在里面,很喜欢游戏的瞄准功能.总的来说项目完成的 ...
- Python强化训练笔记(六)——让字典保持有序性
python的字典是一个非常方便的数据结构,使用它我们可以轻易的根据姓名(键)来找到他的成绩,排名等(值),而不用去遍历整个数据集. 例如:{'Lee': [1, 100], 'Jane': [2, ...