如何判断两个类之间的差异

代码实现
package net.mindview.util;
import java.util.*;
public class Sets {
	public static <T> Set<T> union(Set<T> a,Set<T> b){
		Set<T> result=new HashSet<T>(a);
		result.addAll(b);
		return result;
	}
	public static <T> Set<T> intersection(Set<T> a,Set<T> b){
		Set<T> result=new HashSet<T>(a);
		result.retainAll(b);
		return result;
	}
	public static <T> Set<T> difference(Set<T> superset,Set<T> subset){
		Set<T> result=new HashSet<T>(superset);
		result.removeAll(subset);
		return result;
	}
	public static <T> Set<T> complement(Set<T> a,Set<T> b){
		return difference(union(a,b),intersection(a,b));
	}

}

 

package net.mindview.util;
import java.lang.reflect.Method;
import java.util.*;
public class ContainerMethodDifferences {

	/**
	 * 打印出java.util包中各种Collection和Map类之间的方法差异
	 */
	static Set<String> methodSet(Class<?> type){
		Set<String> result=new TreeSet<String>();
		for(Method m:type.getMethods()){
			result.add(m.getName());
		}
		return result;
	}
	static void interfaces(Class<?> type){
		System.out.println("Interfaces in "+type.getSimpleName()+":");
		List<String> result=new ArrayList<String>();
		for(Class<?> c:type.getInterfaces()){
			result.add(c.getSimpleName());
		}
		System.out.println(result);
	}
	static Set<String> object=methodSet(Object.class);
	static{
		object.add("clone");
	}
	static void difference(Class<?> superset,Class<?> subset){
		System.out.println(superset.getSimpleName()+" extends "+subset.getSimpleName()+" ,adds:");
		Set<String> comp=Sets.difference(methodSet(superset), methodSet(subset));
		comp.removeAll(object);
		System.out.println(comp);
		interfaces(superset);
	}
	public static void main(String[] args) {
		System.out.println("Collection: "+methodSet(Collection.class));
		interfaces(Collection.class);
		difference(Set.class,Collection.class);
		difference(HashSet.class,Set.class);
		difference(LinkedHashSet.class,HashSet.class);
		difference(TreeSet.class,Set.class);
		difference(List.class,Collection.class);
		difference(ArrayList.class,List.class);
		difference(LinkedList.class,List.class);
		difference(Queue.class,Collection.class);
		difference(PriorityQueue.class,Queue.class);
		System.out.println("Map: "+methodSet(Map.class));
		difference(HashMap.class,Map.class);
		difference(LinkedHashMap.class,HashMap.class);
		difference(SortedMap.class,Map.class);
		difference(TreeMap.class,Map.class);
		

	}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值