(一)下文转自https://blog.csdn.net/qq_27029491/article/details/45531845
1、Map<String,String> m=new HashMap<String,String>()
Map是个接口HashMap是它的实现类。 这就是new 了一个对象
2、HashMap<String,String> hashMapOut=new HashMap<String,String>()
a、 这种申明方式没有问题。.
只不过一般习惯在前面使用接口来进行创建,如下
Map<String,String> map = new HashMap<String,String>();
b、这句话没有问题,只是用实现类来声明了实现类,一般情况下 都是用接口来声明的
c、面向接口的好处是你可以随时修改这个具体的实现
问题:
1、HashMap<int,String> map=new HashMap<int,String>(); 这行怎么错了?
eclipse报错为: Syntax error on token "int", Dimensions expected after this token
这个链接也有说明 :http://blog.csdn.net/dingherry/article/details/5944285, 但是说的不清楚.
为什么基本数据类型不行? 非要把int 改为integer?
答案:
规则和限制
1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。
2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。
3、泛型的类型参数可以有多个。
4、泛型的参数类型可以使用extends语句,例如<T extends superclass>。习惯上称为“有界类型”。
5、泛型的参数类型还可以是通配符类型。例如Class<?> classType = Class.forName("java.lang.String");
2、new HashMap() 和 new HashMap<String,String> 有啥区别?
使用 Map 的时候发现好多地方是这样实例化的:new HashMap<String,String>() , 就是把Map里面的元素的类型也写进去?写和不写有啥区别?性能上有没有好处?
答案:
在运行期没有任何区别, java的泛型只在编译期有效, 只是为了写代码的时候多一些约束少一些出错而已,
木得区别,还是推荐指定类型,一如楼上所说多一些约束,二是取值的时候更省事,不用显式类型转换,最重要的一点是提高代码可读性。
new HashMap(),放进去的元素默认是Object类型的, 取出来的时候的时候要向下转型,容易发生错误啊,加上泛型,编译时就能确定类型了。
(二)下文转自https://blog.csdn.net/sjjmuma/article/details/51818567
HashMap你可以理解成是一对对数据的集合我暂时把List 改成String 你方便理解
Map<String, String> map=new HashMap<String,String>(),
map.put(key,value);
key可以理解成房子 value 可以理解成 住户名(这儿假设一个大学宿舍只能住一个人)
map.put("S301","张三");
那就是说S301 这个房间 只有 张三这么个住户
map.put("S301","张三");
map.put("S301","李四");
那只保留map.put("S301","李四"); 因为只能住一个 张三被赶出来了
Productlist.get(key); 就是根据房间号 获取对应的住户名
然后执行 String sss=map.get("S301");
以后 sss="李四"
实际上 key 和value 可以是任何对象 这儿只是拿string 举例 现在改回来Map<String, List> map=new HashMap<String,List>(),
List就是一个数据列表 你现在而已理解成 一个名字的列表List<String> list = new LinkedList<String>();
list.add("张三");
list.add("李四");
list.add("王五");
然后 我们假设S301是个大学宿舍 能住很多人
list就是名字列表map.put("S301",list);
那样的话 就能储存S301所有住户的名字了同样 可以保存 所有宿舍楼的信息
map.put("S302",list1);
map.put("S303",list2);