Java SE 046 迭代器、TreeSet及Comparator深度剖析

(1)一个人只要自己不放弃自己,整个世界也不会放弃你.
(2)天生我才必有大用
(3)不能忍受学习之苦就一定要忍受生活之苦,这是多么痛苦而深刻的领悟.
(4)做难事必有所得
(5)精神乃真正的刀锋
(6)战胜对手有两次,第一次在内心中.
(7)编写实属不易,若喜欢或者对你有帮助记得点赞+关注或者收藏哦~

Java SE 046 迭代器、TreeSet及Comparator深度剖析

1.使用迭代函数

在使用迭代函数访问类集之前,必须得到一个迭代函数。每一个Collection类都提供一个iterator()函数,该函数返回一个对类集头的迭代函数。通过使用这个迭代函数对象,可以访问类集中的每一个元素,一次一个元素。通常,使用迭代函数循环通过类集的内容,步骤如下:
(1)通过调用类集iterator()方法获得对类集头的迭代函数。
(2)建立一个调用hashNext()方法的循环,只要hashNext()返回true,则进行迭代循环。
(3)在循环内部,通过调用next()方法来得到每一个元素。

package com.javase.hashset;

import java.util.HashSet;
import java.util.Iterator;

public class SetTest4 {
	@SuppressWarnings("unchecked")
	public static void main(String[] args) {
		HashSet set = new HashSet();
		set.add("a");
		set.add("b");
		set.add("c");
		set.add("d");
		set.add("e");
		
		for(Iterator iter = set.iterator(); iter.hasNext();){
			String value = (String)iter.next();
			System.out.println(value);
		}
	}
}

2.TreeSet

(1)自然排序(不指定排序规则)

package com.javase.hashset;

import java.util.TreeSet;

public class TreeSetTest {

	@SuppressWarnings("unchecked")
	public static void main(String[] args) {
		TreeSet set = new TreeSet();
		set.add("c");
		set.add("e");
		set.add("b");
		set.add("d");
		set.add("a");
		set.add("f");
		System.out.println(set);
	}

}

(2)TreeSet add方法存在的问题
如果指定的对象不能够与当前集合中已经存在的对象进行比较就会抛出ClassCastException。

package com.javase.hashset;

import java.util.TreeSet;

public class TreeSetTest2 {

	@SuppressWarnings("unchecked")
	public static void main(String[] args) {
		TreeSet set = new TreeSet();
		Person p1 = new Person(10);
		Person p2 = new Person(20);
		Person p3 = new Person(30);
		Person p4 = new Person(40);
		Person p5 = new Person(50);
		
		set.add(p1);
		set.add(p2);
		set.add(p3);
		set.add(p4);
		set.add(p5);
		
		System.out.println(set);
	}
	
}

class Person{
	
	int score;
	
	public Person(int score){
		this.score = score;
	}
	
	@Override
	public String toString() {
		return String.valueOf(score);
	}
}

Person对象是不可以比较的

(3)要想往TreeSet里面放置对象,并且对象可以进行比较,我们必须要指定一套排序规则,前提是放进去的对象本身,它没有一个所谓的自然的顺序.也就是说,对于自定义的类型,必须明确的指定好一种排序规则.
不可以比较的

(3)要想往TreeSet里面放置对象,并且对象可以进行比较,我们必须要指定一套排序规则,前提是放进去的对象本身,它没有一个所谓的自然的顺序.也就是说,对于自定义的类型,必须明确的指定好一种排序规则.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值