Map和泛型

本文详细介绍了Java中的Map和泛型概念。从泛型的安全机制、泛型中的E问题,到自定义泛型类、泛型接口、泛型通配符和限定,深入探讨了泛型的各个方面。接着,文章涵盖了Map接口及其重要方法,如put、get、containsKey等,并讲解了Map集合的遍历方式。最后,文章列举并解析了HashMap、LinkedHashMap、Hashtable、Vector、TreeMap以及Properties等集合类的特点和使用场景。
摘要由CSDN通过智能技术生成

Map和泛型

1. 泛型 Generic

​ 泛型技术是JDK版本一大升级,源自于JDK1.5

​ 泛型就是集合类**<泛型>**

//无泛型写法
public static void main(String[] args) {
   
    /**
       *  JDK没有泛型技术,就是这样写
       *  集合可以存储任何数据类型
       *  添加元素的数据类型是Object
       */
    List list = new ArrayList();
    list.add("a");
    list.add(1);
    Iterator it = list.iterator();
    while (it.hasNext()){
   
        Object obj = it.next();//不能类型转换
        System.out.println(obj);
    }
}

1.1 泛型的安全机制

软件升级 : 安全性提高,修复Bug错误,改善用户体验,增加功能,提升性能

JDK1.5里程碑版本

泛型作用 : 强制了集合存储固定的数据类型

泛型的书写格式 :

集合类<存储的数据类型>  变量名 = new 集合类<存储的数据类型>();
                                       类型可以不写:钻石操作符

加入泛型后,程序的安全性提升了

    public static void main(String[] args) {
   
        /**
         *  JDK没有泛型技术,就是这样写
         *  集合可以存储任何数据类型
         *  添加元素的数据类型是Object
         */
        List<String> list = new ArrayList<String>();
        list.add("a");
        list.add(1); //编译错误,数据类型不匹配

        Iterator<String> it = list.iterator();
        while (it.hasNext()){
   
            String obj =it.next(); //类型转换不需要
            System.out.println(obj);
        }
    }
  • 使用泛型的好处 :
    • 安全性提高了
    • 程序的代码量减少
    • 避免了类型的强制转换
    • 程序的问题,由运行时期,提前到编译时期

1.2 泛型中的 E 问题

E没有什么实际价值,只是一个变量而已

特殊 : 等待接收指定的数据类型

ArrayList<E>
//创建对象
ArrayList<String> al = new ArrayList<String>();
E 不在是E了,变成String

public boolean add(String e) {
   

}

1.3 自定义泛型类

/**
 *  定义类,类名叫工厂
 *  自定义泛型类
 *  Factory<什么都可以写> 只是变量名而已
 */
public class Factory<QQ> {
   
    private QQ q;

    public void setQ(QQ q){
   
        this.q = q;
    }

    public QQ getQ(){
   
        return q;
    }
}
public static void main(String[] args) {
   
    //创建对象Factory类对象
    // Factory factory = new Factory();//没有泛型,QQ就是Object

    Factory<String> factory = new Factory<String>();
    factory.setQ("abc");
    String s = factory.getQ();
    System.out.println(s);

    Factory<Double> factory2 = new Factory<Double>();
    factory2.setQ(1.5);
    Double q = factory2.getQ();
    System.out.println(q);
}

1.4 泛型方法

/**
 * 泛型的方法,方法参数上
 */
public class Factory<Q> {
   

    /*
     * 静态方法
     * Q是非静态的, Q的数据类型,是new的时候指定的
     *
     * 静态方法参数中的泛型,不能和类一样
     * 静态方法的泛型,需要在方法上单独定义
     * 写在返回值类型的前面
     */
    public static <T> void staticMethod(T q){
   
        System.out.println(q);
    }

    public void print(Q q){
   
        System.out.println(q);
    }
}

1.5 泛型接口

  • 实现类实现接口,不实现泛型
  • 实现类实现接口,同时指定泛型
//泛型接口
public interface Inter <T> {
    public abstract void inter(T t);
}

/**
 * 实现接口,不理会泛型
 * 对象创建的时候,指定类型
 */
public class InterImpl<T> implements Inter<T>{
   
    public void inter(T t){
   
        System.out.println(t);
    }
}
/**
 * 实现接口,同时指定泛型
 */
public class InterImpl2 implements Inter<String> {
   

    public void inter(String s) {
   
        System.out.println("s=="+s);
    }
}
public class GenericTest {
   
    public static void main(String[] args) {
   
        Inter<String> in = new InterImpl<String>();
        in.inter("ok");

        Inter in2 = new InterImpl2()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值