泛型

泛型

JDK1.5版本以后出现新特性。用于解决安全问题,是一个类型安全机制
好处
1、将运行时期出现问题ClassCastException,转移到了编译时期。方便于程序员解决问题。让运行时问题减少,更安全。
2,避免了强制转换麻烦。

  • 提高了程序的安全性
  • 将运行期遇到的问题转移到了编译期
  • 省去了类型强转的麻烦
  • 泛型类的出现优化了程序设计

格式
通过<>来定义要操作的引用数据类型。

在使用java提供的对象时,什么时候写泛型呢?
在集合框架中很常见,只要见到<>就要定义泛型。其实<> 就是用来接收类型的。
当使用集合时,将集合中要存储的数据类型作为参数传递到<>中即可。

泛型类

什么时候定义泛型类?
当类中要操作的引用数据类型不确定的时候,早期定义Object来完成扩展。现在定义泛型来完成扩展。

class Worker {
}

class Student {
}

// 泛型前做法
class Tool {
    private Object obj;

    public void setObject(Object obj) {
        this.obj = obj;
    }

    public Object getObject() {
        return obj;
    }
}

// 泛型类
class Utils<QQ> {
    private QQ q;

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

    public QQ getObject() {
        return q;
    }
}

class GenericDemo3 {
    public static void main(String[] args) {
        Utils<Worker> u = new Utils<Worker>();
        u.setObject(new Worker());
        Worker w = u.getObject();// 现在不需要强转了。如该Worker传成了Student,编译时会提示类型转换异常;因Utils<Worker>中限定了传入类型
        /*
         * Tool t = new Tool(); 
         * t.setObject(new Student()); 
         * Worker w = (Worker)t.getObject();
         */
        // 编译没问题,运行出错: Exception in thread "main" java.lang.ClassCastException: Student cannot be cast to Worker
    }
}

泛型方法

泛型类定义的泛型,在整个类有效。如果被方法使用,那么泛型类的对象明确要操作的具体类型后,所有要操作的类型就已经固定了。
为了让不同方法可以操作不同类型,而且类型还不确定。那么可以将泛型定义在方法上。
泛型放修饰符后,返回值类型前。
特殊之处:
静态方法不可以访问类上定义的泛型。(会报错: 无法从静态上下文中引用非静态类型变量 T。对象的类型T,建立对象后才知道T到底是什么类型)如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。

class Demo<T> {// 泛型类
    public void show(T t) {// 用了类里面的泛型
        System.out.println("show:" + t);
    }

    // public <T> void print(T q) // 没问题,为阅读方便不写<T>写<Q>
    // Q写成T也没关系,这个方法中的变量与上个方法没关系,都是自定义的
    public <Q> void print(Q q) {// 泛型方法
        System.out.println("print:" + q);
    }

    // public static void method(T t) //静态方法不可以访问类上定义的泛型
    // 编译失败,错误: 无法从静态上下文中引用非静态 类型变量 T(对象的类型T,建立对象后才知道T到底是什么类型)
    public static <W> void method(W t) {
        // 泛型放修饰符后,返回值类型前(<W>不能放static前、void后)
        System.out.println("method:" + t);
    }
}
class GenericDemo4 {
    public static void main(String[] args) {
        Demo<String> d = new Demo<String>(); // 确定泛型的类型
        d.show("haha");
        // d.show(4);//编译失败,泛型规定了参数只能是String
        d.print(5);
        d.print("hehe");
        Demo.method("hahahahha");
    }
}

泛型接口

interface Inter<T> { //泛型接口
    void show(T t);
}
class InterImpl<T> implements Inter<T> {
    public void show(T t) {
        System.out.println("show :" + t);
    }
}
public class GenericDemo5 {
    public static void main(String[] args) {
        InterImpl<Integer> i = new InterImpl<Integer>();
        i.show(4);
    }
}

泛型限定

?:通配符。也可以理解为占位符。

泛型的限定:
? extends E:可以接收E类型或者E的子类型。上限
? super E:可以接收E类型或者E的父类型。下限

class GenericDemo6 {
    public static void main(String[] args) {
        ArrayList<Student> al1 = new ArrayList<Student>();
        // ArrayList<? extends Person> al = new ArrayList<Student>();
        al1.add(new Student("abc--1"));
        al1.add(new Student("abc--2"));
        al1.add(new Student("abc--3"));
        printColl(al1);
    }

    // 泛型限定,限定类型对象使用该方法
    public static void printColl(Collection<? extends Person> al) {
        Iterator<? extends Person> it = al.iterator();
        while (it.hasNext()) {
            System.out.println(it.next().getName());
        }
    }
}
public class Person {
    private String name;
    Person(String name) {
        this.name = name;
    }
    public String getName() {
        return name;
    }
}
class Student extends Person {
    Student(String name) {
        super(name);
    }
}
以下是对提供的参考资料的总结,按照要求结构化多个要点分条输出: 4G/5G无线网络优化与网规案例分析: NSA站点下终端掉4G问题:部分用户反馈NSA终端频繁掉4G,主要因终端主动发起SCGfail导致。分析显示,在信号较好的环境下,终端可能因节能、过热保护等原因主动释放连接。解决方案建议终端侧进行分析处理,尝试关闭节电开关等。 RSSI算法识别天馈遮挡:通过计算RSSI平均值及差值识别天馈遮挡,差值大于3dB则认定有遮挡。不同设备分组规则不同,如64T和32T。此方法可有效帮助现场人员识别因环境变化引起的网络问题。 5G 160M组网小区CA不生效:某5G站点开启100M+60M CA功能后,测试发现UE无法正常使用CA功能。问题原因在于CA频点集标识配置错误,修正后测试正常。 5G网络优化与策略: CCE映射方式优化:针对诺基亚站点覆盖农村区域,通过优化CCE资源映射方式(交织、非交织),提升RRC连接建立成功率和无线接通率。非交织方式相比交织方式有显著提升。 5G AAU两扇区组网:与三扇区组网相比,AAU两扇区组网在RSRP、SINR、下载速率和上传速率上表现不同,需根据具体场景选择适合的组网方式。 5G语音解决方案:包括沿用4G语音解决方案、EPS Fallback方案和VoNR方案。不同方案适用于不同的5G组网策略,如NSA和SA,并影响语音连续性和网络覆盖。 4G网络优化与资源利用: 4G室分设备利旧:面对4G网络投资压减与资源需求矛盾,提出利旧多维度调优策略,包括资源整合、统筹调配既有资源,以满足新增需求和提质增效。 宏站RRU设备1托N射灯:针对5G深度覆盖需求,研究使用宏站AAU结合1托N射灯方案,快速便捷地开通5G站点,提升深度覆盖能力。 基站与流程管理: 爱立信LTE基站邻区添加流程:未提供具体内容,但通常涉及邻区规划、参数配置、测试验证等步骤,以确保基站间顺畅切换和覆盖连续性。 网络规划与策略: 新高铁跨海大桥覆盖方案试点:虽未提供详细内容,但可推测涉及高铁跨海大桥区域的4G/5G网络覆盖规划,需考虑信号穿透、移动性管理、网络容量等因素。 总结: 提供的参考资料涵盖了4G/5G无线网络优化、网规案例分析、网络优化策略、资源利用、基站管理等多个方面。 通过具体案例分析,展示了无线网络优化中的常见问题及解决方案,如NSA终端掉4G、RSSI识别天馈遮挡、CA不生效等。 强调了5G网络优化与策略的重要性,包括CCE映射方式优化、5G语音解决方案、AAU扇区组网选择等。 提出了4G网络优化与资源利用的策略,如室分设备利旧、宏站RRU设备1托N射灯等。 基站与流程管理方面,提到了爱立信LTE基站邻区添加流程,但未给出具体细节。 新高铁跨海大桥覆盖方案试点展示了特殊场景下的网络规划需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值