能够通过哈希表实现高效的集合操作。
接口
一个集合对象能够包括了下面接口:
public interface Set<Key extends Comparable<Key>> {
public void add(Key key);
public boolean contains(Key key);
public void remove(Key key);
public int size();
public Iterator<Key> iterator();
}
黑名单过滤应用
代码
import java.util.Set;
import java.util.LinkedHashSet;
public class BlackList {
public static void main(String[] argv) {
String[] urls = new String[]{"baidu.com", "abc.com", "porn.com", "youtube.com", "facebook.com"};
String[] blacklist = new String[]{"porn.com", "youtube.com", "facebook.com"};
// 建立黑名单集合
Set<String> black = new LinkedHashSet<String>();
for(String b : blacklist) {
black.add(b);
}
// 过滤非法站点
for(String url : urls) {
if(!black.contains(url)) {
System.out.println(url);
}
}
}
}
输出结果:
baidu.com
abc.com
porn.com is blocked
youtube.com is blocked
facebook.com is blocked
从输出结果中能够看出,一些非法站点被过滤了。