java集合类(二)

第十六天知识点总结

一、泛型

泛型:java jdk 1.5 新特性。

泛型的好处:

1.运行时的错误提前到编译时。

2.避免无谓的强制类型转换

自定义方法泛型:自定义泛型就是一个数据类型的占位或一个数据类型变量,一般用T或E来做这个占位符号,占位符号可以随意写,但是必须遵守标识符的命名规范

方法泛型的格式:

<占位符> T : 定义了一个泛型

举例:

Public  static  <T>T  test(T s){

Return  s;

}

如果你传进去的是一个基本数据类型:接收的时候应该用它的包装类来接收.

int Integer  short Short  double Double  float Float  byte Byte

boolean  Boolean  long Long  char charactor

自定义数组的工具类

定义一个泛型类:

定义格式

class 类名<声明自定义的泛型> { }

泛型类的使用注意点:

1.泛型类上定义的自定义泛型的类型是在创建这个类对象时确定的。

2.如果一个自定义泛型的类,在创建对象时没有指定,默认为Object类型。

3.静态方法不能够使用类删自定义的泛型,必须在方法上定义一个泛型。

泛型接口:

泛型接口的定义方式:

Interface 接口名<声明自定义的泛型> {   }

接口泛型的使用注意点:

1.接口上自定义的泛型在实现接口的时候被指定的

2.如果实现接口是没有指定接口 ,那么就会默认为Object

3.需要在创建接口实现类对象是指定数据类型,

那么需要格式:class 类名<声明自定义泛型> implements 接口<声明自定义泛型>

判断下列写法是否错误:

ArrayList<String> list1 = new ArrayList<String>(); //true

ArrayList<String> list2 = new ArrayList<Integer>();//false

ArrayList<Integer> list3 = new ArrayList<String>();//false

1. ArrayList list4 = new ArrayList<String>();//true

2. ArrayList<String> list5 = new ArrayList();//true

推荐使用第一种

二、Map集合

Map集合 接口 双列集合 key:value 类似于OC中的字典

特点:存储数据是以键和值的方式,键不允许重复,值可以重复

-----> HashMap 基于哈希表来存储数据的

存储原理也使用哈希表来存放:

往HashMap添加了元素,首先会调用键的hashCode方法获得一个哈希值,然后经过运算获取一个位置。

情况一:如果位置上没有元素,那么直接将该元素存放在此位置。

情况二:如果位置上有元素,那么还会调用元素的equals方法与位置上的元素做比较,如果返回的是true,那么就被视为相同的键,就不存了,反之返回的是false,那么就可以存放该元素。

-----> TreeMap:基于二叉树的结构存储,特点:以键来做自然排序

使用注意点:

1.往TreeMap里添加元素时,如果元素的键具备自然排序功能,那么就会通过自然排序进行排序。

2.往TreeMap里添加元素时,如果元素的键不具备自然排序功能,键所属的类必须要实现Comparable接口,把这个键的比较规则定义在compareTo方法中。

3.往TreeMap里添加元素时,如果元素的键不具备自然排序功能,也没有实现Comparable接口,创建TreeMap的时候给他一个比较器

结构:

Class 类名implements Compartor 接口{

}

键的比较规则定义在compare方法中。

-----> HashTable :HashMap 一样的使用,线程安全。访问比较慢(了解)

Map集合的使用注意点:

1.键可以是任意对象,值也可以是任意对象

2.Map集合中是可以嵌套list集合

(重点掌握)Map集合常用的方法:

添加:put(K key, V value);

putAll(Map <?extends K,?extends V>  m);

删除:clear();

remove(Object key);

获取:get(Object key);

Size();

判断:isEmpty();

containsKey(Object key);

containsValue(Object value);

Map集合的遍历方式:

通过迭代器来遍历:

entrySet();

keySet();

values();

Map.Entry: 接口:提供给用户来操作map集合

getKey(); 获取键

getValue();获取值

setValue();更改值

时间: 2024-12-24 18:32:11

java集合类(二)的相关文章

Java常见面试题(二)JAVA集合类

JAVA集合类图: 1. hashmap原理,与hashtable区别 Java中的HashMap是以键值对(key-value)的形式存储元素的.HashMap需要一个hash函数,它使用hashCode()和equals()方法来向集合/从集合添加和检索元素.当调用put()方法的时候,HashMap会计算key的hash值,然后把键值对存储在集合中合适的索引上.如果key已经存在了,value会被更新成新值.HashMap的一些重要的特性是它的容量(capacity),负载因子(load

Java集合类相关面试题

1.Collection和Collections的区别 java.util.Collection 是一个集合接口,Collection接口在Java类库中有很多具体的实现,例如List.Set java.util.Collections 是针对集合类的一个帮助类,它提供了一系列的静态方法实现对各种集合的搜索.排序.线程安全化等操作. 2.ArrayList与Vector的区别 这两个类都实现了List接口(List接口继承自Collection接口).它们都是有序集合,它们内部的元素都是可以重复

java集合类编程重点

一.数组常用操作 import java.io.*; import java.math.*; import java.util.*; public class Main { private static int []a=new int[20]; public static void print() { for(int i=0;i<20;i++) System.out.print(a[i]+" "); System.out.println(""); } publ

Java集合类汇总记录--guava篇

BiMap HashBiMap<K,V> 实现了两份哈希表数据结构(本类独立实现),分别负责两个方向的映射. EnumBiMap<K,V> 两个EnumMap对象分别负责两个方向的映射. EnumHashBiMap<K,V> 一个EnumMap对象负责K到V映射,一个HashMap对象负责V到K的影身. MultiMap HashMultimap<K,V> 使用HashMap<K,HashSet<V>>对象实现. TreeMultim

【转载】Java集合类Array、List、Map区别和联系

Java集合类主要分为以下三类: 第一类:Array.Arrays第二类:Collection :List.Set第三类:Map :HashMap.HashTable 一.Array , Arrays Java所有"存储及随机访问一连串对象"的做法,array是最有效率的一种. 1.效率高,但容量固定且无法动态改变.array还有一个缺点是,无法判断其中实际存有多少元素,length只是告诉我们array的容量. 2.Java中有一个Arrays类,专门用来操作array .array

一张图让你看清Java集合类(Java集合类的总结)

如今关于Java集合类的文章非常多,可是我近期看到一个非常有意思图片,基本上把Java集合的整体框架都给展现出来了.非常直观. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaWFtenAyMDA4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" align="middle" > 假设发现图片看不清楚.点此处看大图 在这里,

Java集合类简单总结(重学)

java集合类简介(重学) 一.Collection(集合).Map接口两者应该是平行关系吧. 1.Map介绍 Map是以键值(key-value)对来存放的,2个值.通过key来找到value(例:姓名-电话,通过姓名得到电话),通过Map创建的对象key都 不可以重复. 它的两个常用子类:HashMap类和HashTable类. HashMap类:无序存放的,key不允许重复 HashTable类:无序存放,key不允许重复 key值可通过Map的方法keyset获取全部的key值,返回是个

Java集合类的总结

现在关于Java集合类的文章很多,但是我最近看到一个很有意思图片,基本上把Java集合的总体框架都给展现出来了,很直观. 如果发现图片看不清楚,点此处看大图 在这里,集合类分为了Map和Collection两个大的类别. 处于图片左上角的那一块灰色里面的四个类(Dictionary.HashTable.Vector.Stack)都是线程安全的,但是它们都是JDK的老的遗留类,现在基本都不怎么使用了,都有了对应的取代类.其中Map是用来代替图片中左上角的那个Dictionary抽象类(Map的官方

Java集合类汇总记录--JDK篇

接口类图 Java Collection由两套并行的接口组成,一套是Collection接口,一套是Map接口.如下图 公共抽象类AbstractCollection 要求派生类实现iterator()方法,AbstractCollection根据得到的Iterator实现所有可以支持的方法,比如remove().contains().toArray().toString()等. 当然,Map系列的类并不从AbstractCollection派生. List实现 AbstractList 要求子