zl程序教程

您现在的位置是:首页 >  后端

当前栏目

泛型类、Map集合详解编程语言

2023-06-13 09:20:39 时间

————泛型: 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

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();

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/13460.html

cjava