Collection of java

hashCode() and equals()方法详解

1.关于Object类的equals()方法的特点?

a)自反性(reflexive):x.equals(x)应该返回true

b)对称性(symmetric):x.equals(y)为true,那么y.equals(x)也为true

c)传递性(transitive):x.equals(y)为true并且y.equals(z)为true,那么x.equals(z)也应该为true。

d)一致性(consistent):x.equals(y)的第一次调用为true,那么x.equals(y)的第二次、第三次、第n次也应该为true,前提条件是在比较之间没有修改x也没有修改y。

e)对于非空引用x,x.equals(null)返回false。

2.关于Object类的hashCode()方法的特点?

a)在java应用的一次执行过程中,对于同一个对象的hashCode()方法的多次调用,他们应该返回同样的值(前提是该对象的信息没有发生变化)。

b)对于两个对象来说,如果使用equals()方法比较返回true,那么这两个对象的hashCode()的值也一定相同。

c)对于两个对象来说,如果使用equals()方法比较返回false,那么这两个对象的hashCode()的值不要求一定不同(可以相同,可以不同),但是如果不同则可以提高应用的性能。

d)对于Object类来说,不同的Object对象的hashCode值是不同(Object类的hashCode值表示的是对象的地址)。

3.当使用HashSet时,hashCode()方法就会得到调用,判断已经存储在集合中的对象的hash Code值是否与增加的对象的hash code值一致;如果不一致,直接加进去;如果一致,再进行equals()方法的比较,equals()方法返回true,表示对象已经加进去了,就不会再增加新的对象了。否则,加进去了。

4.如果我们重写equals()方法,那么也要重写hashCode()方法。反之亦然。

迭代器、TreeSet及Comparator详解

package SetTest;

import java.util.HashSet;

import java.util.Iterator;

public class HashSetTest {

public static void main(String[] args) {

HashSet<String> set = new  HashSet<String>();

set.add("a");

set.add("b");

set.add("c");

set.add("d");

//while循环

Iterator<String> iterator = set.iterator();

while(iterator.hasNext()){

String value = iterator.next();

System.out.print(value +" ");

}

System.out.println("============");

//for循环

for(Iterator<String> i = set.iterator();i.hasNext();){

String value = iterator.next();

System.out.print(value+" ");

}

}

}

package SetTest;

import java.util.TreeSet;

public class TreeSetTest {

public static void main(String[] args) {

TreeSet<String> set = new TreeSet<String>();

set.add("a");

set.add("b");

set.add("f");

set.add("c");

set.add("d");

System.out.println(set);

}

}

package SetTest;

import java.util.Comparator;

import java.util.Iterator;

import java.util.TreeSet;

public class TreeSetTest3 {

public static void main(String[] args) {

TreeSet set = new TreeSet(new MyComparator());

set.add("c");

set.add("a");

set.add("b");

set.add("e");

set.add("f");

set.add("d");

for(Iterator iterator = set.iterator();iterator.hasNext();){

String value = (String)iterator.next();

System.out.print(value +" ");

}

}

}

class MyComparator implements Comparator{

@Override

public int compare(Object o1, Object o2) {

String v1 =(String) o1;

String v2 = (String) o2;

return v2.compareTo(v1);

}

}

package SetTest;

import java.util.Comparator;

import java.util.TreeSet;

public class TreeSetTest2 {

public static void main(String[] args) {

TreeSet set = new TreeSet(new MyComparator1());

Person p1 = new Person(10);

Person p2 = new Person(20);

Person p3 = new Person(30);

Person p4 = new Person(40);

set.add(p1);

set.add(p2);

set.add(p3);

set.add(p4);

System.out.println(set);

}

}

class Person{

int score;

public Person(int score){

this.score = score;

}

@Override

public String toString() {

return String.valueOf(this.score);

}

}

class MyComparator1 implements Comparator{

@Override

public int compare(Object o1, Object o2) {

Person p1 = (Person)o1 ;

Person p2 = (Person)o2 ;

return p1.score - p2.score;

}

}

package SetTest;

import java.util.Collections;

import java.util.Comparator;

import java.util.Iterator;

import java.util.LinkedList;

public class CollectionsTest {

public static void main(String[] args) {

LinkedList list = new LinkedList();

list.add(new Integer(-8));

list.add(new Integer(20));

list.add(new Integer(-20));

list.add(new Integer(8));

Comparator r =Collections.reverseOrder();

Collections.sort(list);

for(Iterator iterator =list.iterator() ;iterator.hasNext();){

Integer value = (Integer)iterator.next();

System.out.print(value.intValue() +" " );

}

}

}

Map深入详解及遍历Map的两种实现手段

package SetTest;

import java.util.HashMap;

public class MapTest1 {

public static void main(String[] args) {

HashMap map = new HashMap();

map.put("a", "zhangsan");

map.put("b", "lisi");

map.put("c", "wangwu");

map.put("a", "zhaoliu");

System.out.println(map);

}

}

Map(映射):Map的KeySet()方法会返回Key的集合,因为Map的键是不能重复的。因此KeySet方法的返回类型是Set;而Map的值是可以重复的,因value()方法的返回值类型是Collection,可以容纳重复的元素。

package SetTest;

import java.util.Collection;

import java.util.HashMap;

import java.util.Iterator;

import java.util.Set;

public class HashMapTest2 {

public static void main(String[] args) {

HashMap map = new HashMap();

map.put("a", "aa");

map.put("b", "bb");

map.put("c", "cc");

map.put("d", "dd");

map.put("e", "ee");

Set set = map.keySet();

for(Iterator iterator = set.iterator();iterator.hasNext();){

String key = (String)iterator.next();

String value = (String)map.get(key);

System.out.print("键:"+key+"值:"+value);

}

Collection collection = map.values();

System.out.println(set +"\t" +collection);

}

}

package SetTest;

import java.util.Collection;

import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Set;

public class HashMapTest2 {

public static void main(String[] args) {

HashMap map = new HashMap();

map.put("a", "aa");

map.put("b", "bb");

map.put("c", "cc");

map.put("d", "dd");

map.put("e", "ee");

Set set = map.entrySet();

for(Iterator iterator = set.iterator();iterator.hasNext();){

Map.Entry entry = (Map.Entry)iterator.next();

String key = (String)entry.getKey();

String value = (String)entry.getValue();

System.out.println(key+":"+value);

}

}

}

时间: 2024-08-27 14:38:36

Collection of java的相关文章

【DateStructure】 Charnming usages of Map collection in Java

When learning the usage of map collection in java, I found serveral beneficial methods that was encountered in the daily life. Now  I made a summary: [java] view plaincopy import java.util.ArrayList; import java.util.Collections; import java.util.Com

Collection Map Java数据结构

Collection Map 框架图 Collection          接口的接口   对象的集合 ├ List                   子接口      按进入先后有序保存   可重复 │├ LinkedList                接口实现类   链表   插入删除   没有同步   线程不安全 │├ ArrayList                  接口实现类   数组   随机访问   没有同步   线程不安全 │└ Vector             

Java基础知识强化之集合框架笔记07:Collection集合的遍历之迭代器遍历

1. Collection的迭代器: 1 Iterator iterator():迭代器,集合的专用遍历方式 2. 代码示例: package cn.itcast_03; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; /* * Iterator iterator():迭代器,集合的专用遍历方式 * Iterator(迭代器): * Object next():获取元素,并移动

疯狂Java学习笔记(34)----------Iterator、Collection接口以及foreach

Iterator.Collection接口: 如下图:Iterator.Collection同在一个包中: 红字部分使我们经常遇到的,但是遇到又不知道怎么去理解,去应用它! Collection是最基本集合接口,它定义了一组允许重复的对象.Collection接口派生了两个子接口Set和List,分别定义了两种不同的存储方式,如下: 2. Set接口 Set接口继承于Collection接口,它没有提供额外的方法,但实现了Set接口的集合类中的元素是无序且不可重复. 特征:无序且不可重复. 3.

java集合学习之Collection(3)

这篇博客主要介绍List集合和Queue集合 一.List集合 List集合是一个有序的可重复的集合,集合中的每个元素都对应一个索引,我们可以通过索引来访问List集合中的数据(其实可以看成一个长度可变的数组). List作为Collection的子接口,支持Collection的所有操作,但因为List是有序的所以新增加了一些新的操作,主要是根据索引来插入,删除,替换元素的方法.List通过equals()方法判断对象是否相等.如下面的代码所示: package lkl; import jav

Java 集合系列 02 Collection架构

java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java 集合系列 04 LinkedList详细介绍(源码解析)和使用示例 首先,我们对Collection进行说明.下面先看看Collection的一些框架类的关系图: Collection是一个接口,它主要的两个分支是:List 和 Set. List和Set都是接口,它们继承于Collection.L

java----数据结构与算法----JavaAPI:java.util.Collection接口

Java API--java.util.Collection接口 /** * @author chen * @date 20170317 * @description:本程序讲述Collection接口 * java.util.Collection * 概述:Collection接口是Set和List接口的父接口,Collection接口中定义了一些 * 用于集合元素操作的方法,被其子接口以及子接口的实现类所继承 * 构造函数 * java中接口不能有构造函数 * 成员函数: * [1]概述,由

Java基础之集合框架(Collection接口和List接口)

首先我们说说集合有什么作用. 一.集合的作用 1.在类的内部,对数据进行组织: 2.简单而快速的搜索大数量的条目: 3.有的集合接口,提供一系列排列有序的元素,并且可以在序列中间快速的插入或者删除有关元素: 例如:做广播操的时候,可以将学生插入到某排某列,反之也可以叫某排某列中的学生出列. 4.有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找到对应的唯一对象,而这个关键字可以是任意类型. 例如:在吃饭的时候,众多铝饭盒中如何区别是自己的呢?在饭盒上刻独有的标志或贴纸条,这个标志和

[Java] 垃圾回收 ( Garbage Collection ) 的步骤演示

关于 JVM 垃圾回收机制的基础内容,可参考上一篇博客 垃圾回收机制 ( Garbage Collection ) 简介 上一篇博客,介绍了堆的内存被分为三个部分:年轻代.老年代.永生代.这篇博文将演示这三个部分如何交互,实际也演示了垃圾回收. 1. 首先,所有新创建的对象都会陪分配到年轻代的 Eden 空间,而两个 survior 空间一开始都为空. 下图表示的是运行一段实际后的年轻代内存情况,新创建的对象会被放在 Eden 空间,"from" survior space 里面的数字