————泛型: JDK1.5之后出现的新特性;用于解决安全问题,是一个类型安全机制。
好处:
1、将运行时期出现的问题ClassCastException ,转移到了编译时期,方便于程序员解决问题,让运行时期问题减少。。
2、避免了强制转换的麻烦。
格式:
通过<> 来定义要操作的引用数据类型。
在使用java提供的对象时,什么时候写泛型呢?
答:通常在集合框架中很常见,只要见到<> 就要定义泛型。 其实<>就是用来接收泛型的。
当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可。
泛型类:
什么时候定义泛型类?
答: 当类中要操作的引用数据类型不确定的时候, 早期定义Object类来完成扩展; 现在定义泛型来完成扩展。
泛型类定义的泛型,在整个类中有效,如果被方法使用;
那么泛型类的对象明确要操作的具体类型后,所有要操作的类型就已经固定了。
为了让不同的方法可以操作不同类型,而且类型还不确定,那么就可以将泛型定义在方法上。
特殊之处:
静态方法不可以访问类上定义的泛型。
如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。(在修饰符后面 、 返回值类型前面 :如 static <T> void)。
高级应用:
? : 通配符,也可以理解是占位符。
? extends E : 可以接收E 类型或者 E的子类型,上限。
? super E : 可以接收E 类型或者 E的父类型 ,下限。
————Map集合:该集合存储键值对。 一对一往里存。而且要保证键的唯一性。
1、添加
put(K key, V value);
putAll(Map < ? extends K , ? extends V > m);
2、删除
clear()
remove(Object key)
3、判断
containsValue(Object value)
containsKey(Object key)
isEmpty()
4、获取
get(Object key) size() values()
重要: entrySet() keySet()
Map
|---Hashtable : 底层是哈希表数据结构,不可以存入null 键 null 值。该集合是线程同步的。Jdk1.0 效率低。
|---HashMap : 底层是哈希表数据结构,允许使用 null 键和 null 值。该集合是线程不同步的。Jdk1.2 效率高。
|---TreeMap :底层是二叉树数据结构,线程不同步,可以用于给Map集合中的键进行排序。
和Set很像。
其实Set底层就是使用了Map集合。
添加元素,如果添加时,出现相同的键,那么后添加的值会覆盖原有的键值对。
并put方法会返回 被覆盖的值。 例如:
System.out.println("put :" + map.put( "01" + "jdfkslfh"));
System.out.println("pUt: " + map.out( "01" + "djksl"));
// 打印输出: jdfkslfh 被返回 , 01 键上的值则为 djksl
---可以通过get方法的返回值来判断一个键是否存在,通过返回null来判断
---获取map集合中所有的值。
Collection<String> coll = map.values();
--->>> 1、Set<k> keySet :
将map中所有的键存入到Set集合中。因为Set具备迭代器,所有可以迭代方式取出所有的键,再根据get方法,获取每一个键对应的值。
Map集合的取出原理: 将map结合转换set集合。在通过迭代器取出。
2、Set<Map.Entry<k,v>> entrySet:
将map集合中的映射关系存入到了Set集合中,而这个关系的数据类型就是: Map.Entry。
//先获取集合的所有键的set集合,keySet();
Set<String> keySet = map.keySet();
//有了Set集合,就可以获取其迭代器。
Iterator<String> it = keySet.iterator();