Set接口(HashSet,TreeSet)

HashSet

不能重复,没有顺序,本质上就是HashMap的key,对于这个HashSet大家可以练习一下如下的代码,通过运行程序,查看控制台内容来进一步了解。

import java.util.HashSet;
import java.util.Set;

/** 

* @author Hercules

* @version 创建时间:2020年1月15日 下午2:11:43 

* 学习类

*/
public class SetPratice {
      public static void main(String[] args) {
    	  Set<String> sets = new HashSet<String>();
    	  sets.add("aa");
    	  sets.add("aa1");
    	  sets.add("aa2");
    	  sets.add("aa3");
    	  sets.add("aa");     //不允许重复,所以重新添加的"aa"加不进去
    	  sets.contains("aa");//判断是否存在
    	  sets.add(null);     //可以添加空值进去
    	  for(String s : sets) {
    		  System.out.println(s);
    	  }
    	  System.out.println("********");//用*号分隔开
    	  sets.remove("aa");  //删除元素
    	  
    	  for(String s : sets) {
    		  System.out.println(s);
    	  }
    	  
	  }
}

TreeSet

和HashSet一样实现了Set接口,使用方法和HashSet一样,可以排序,实现排序同样有两种方法,这里我就不很详细的写了,因为在我这篇博文中写的比较详细了链接地址如下:点击此处跳转
下面我就简单介绍下实现方法
1:key的类型实现, java.lang.Comparable < Employee > 接口 实现compareTo方法,根据返回的是正整数0负整数进行排序。
这里还是把代码粘贴出来:

 public class Employee implements Comparable<Employee>{

	private int eNo;
	
	private String name;
	
	private double salary;
	

	public Employee() {
		super();
	}

	public Employee(int eNo, String name, double salary) {
		super();
		this.eNo = eNo;
		this.name = name;
		this.salary = salary;
	}

	public int geteNo() {
		return eNo;
	}

	public void seteNo(int eNo) {
		this.eNo = eNo;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public double getSalary() {
		return salary;
	}

	public void setSalary(double salary) {
		this.salary = salary;
	}

	@Override
	public String toString() {
		return String.format("Employee [eNo=" + eNo + ", name=" + name + ", salary=%6.2f]", salary);
	}

	@Override
	public int compareTo(Employee o) {
		return getSalary() > o.getSalary() ? 1 : getSalary()==o.getSalary() ? 0 : -1;
	}
	
}
  

2、自己实现一个java.util.Comparator实现里面的compare方法根据返回的是正整数0负整数进行排序。

import java.util.Comparator;

public class MyCompare implements Comparator<Employee>{

	@Override
	public int compare(Employee o1, Employee o2) {
		return o1.getSalary() > o2.getSalary() ? 1 : o1.getSalary()==o2.getSalary() ? 0 : -1;
	}

}

使用时传入比较对象
private Set<Employee> employees = new TreeSet<Employee>(new MyCompare());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值