数据结构-初识泛型

这篇具有很好参考价值的文章主要介绍了数据结构-初识泛型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

写在前:

这一篇博客主要来初步的记录以下泛型的相关内容,内容比较琐碎,就不进行目录的整合,后续可能会对泛型这里进行系统性的梳理,此篇博客主要是对泛型有一个简单的认识与理解,需要知晓的内容。

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

当我调用func()的时候,进行传递的是一个真实的数据,是一个数值,在有些情况下,我们会想传递一个数据类型过去。

《Java编程思想》对泛型的介绍:一般的类和方法,只能使用具体的类型:要么是基本类型,要么是自定义类。如果要编写可以应用于多种类型的代码,这种刻板的限制就会对代码的舒服很大。

泛型是在JDK1.5引入的新的语法,通俗讲,泛型就是适用于许多许多类型,从代码上讲,就是对类型实现了参数化。

思考:现在需要我们实现一个类,这个类里面有一个数组,将数组实现成通用的【什么类型的数据都可以存放】,也可以根据方法成员返回数组中的某个下标的值。

我们可以编写出以下的代码:

class MyArray1{
    public Object[] obj = new Object[3];//讲数组定义为Object数组,长度为3,不放数据

    //提供一个方法,getPos,给一个pos下标,就可以返回pos下标对应的值。
    public Object getPos(int pos){
        return obj[pos];
    }

    public void setObj(int pos,Object val){
        obj[pos] = val;
    }
}
public class Test2 {

    public static void main(String[] args) {
        MyArray1 myArray1 = new MyArray1();
        myArray1.setObj(0,10);
        myArray1.setObj(2,"hello");
        myArray1.setObj(3,10.0);
        double d = (double)myArray1.getPos(3);
    }
}

但是我们发现,这样的方法并不是通用的:

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

解决第一个问题:存储数据的时候,什么数据都可存储?

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

可以在这里加上一个<T>,代表的含义是当前类是一个泛型类。

每次进行获取数据的时候都要进行类型的转换

把类型作为参数进行传递。

1.存储数据的时候,可以帮我们进行自动的类型检查。

2.获取元素的时候,可以帮我们进行类型转换。

以上两步都是在编译的时候,泛型是编译时期的一种机制,在运行的时候没有泛型的概念。

规定:泛型当中,不能去实例化一个泛型类型的数组。

小结:

1.泛型是将数据类型参数化,进行传递。

2.使用<T>表示当前类是一个泛型类。

3.泛型目前为止的优点:数据类型参数化,编译时自动进行类型检查和转换。

规定:泛型当中不能去实例化一个泛型类型的数组。

裸类型:裸类型是一个泛型类没有带着类型实参,例如MyArrayList就是一个裸类型。 

问题:Java到底如何进行编译的?

擦除机制!!

泛型的上界【泛型无下界】

在定义泛型类的时候,有时候需要对传入的类型变量做一定的约束,可以通过类型边界来约束。

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

观察以上的代码为什么会报错?

我们使用泛型来进行一个数组中最大值的查找,这里出现了报错,具体原因是因为这里的E类型是一个引用类型,所以就不可以通过大于小于号进行比较,引用类型是通过compare方法来进行比较的。

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

但是这里并没有相关的方法,原因是因为

没有实现接口。:E类型被擦除为Object,Object没有实现对应的接口。

这时就需要我们对E类型进行给《边界》,如果不给边界最终就会被擦除为Object

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

在这里,<E extends N>这个就叫做泛型的上界,代表将来指定的参数类型一定是实现了这个接口的。

<E extends Number> 代表:E是Number的子类或者是Number本身。

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

创建一个新的类A,继承Number,此时,就可以确定使用Number的子类,确定泛型的上界。

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

需要重点注意的内容是泛型有上界,但是泛型是没有下界的。

以上是泛型类,那么是否存在泛型方法?

泛型静态方法:

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言

数据结构-初识泛型,数据结构,JAVA面试,java,开发语言文章来源地址https://www.toymoban.com/news/detail-729551.html

到了这里,关于数据结构-初识泛型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java面试基础|数据结构 -实时更新

    1.HashMap和ConcurrentHashMap介绍 核心是一个Node数组, 数据结构与hashMap相似 使用CAS操作来实现无锁的更新,提高了并发性。当更新节点时,它会使用CAS来替换节点的值或链接,如果CAS失败,表明有其他线程也在进行修改,当前线程可以重试或锁定节点 对于复杂的结构修改操作

    2024年01月17日
    浏览(38)
  • java八股文面试[数据结构]——集合框架

    Java集合类主要由两个根接口Collection和Map派生出来的。 Collection派生出了三个子接口: Map接口派生: Map代表的是存储key-value对的集合,可根据元素的key来访问value。  因此Java集合大致也可分成 List、Set、Queue、Map四种接口体系 。 List代表了有序可重复集合,可直接根据元素的索

    2024年02月11日
    浏览(30)
  • Java面试知识点(全)-数据结构和算法

    Java面试知识点(全)https://nanxiang.blog.csdn.net/article/details/130640392 注:随时更新 数组 数组的下标寻址十分迅速,但计算机的内存是有限的,故数组的长度也是有限的,实际应用当中的数据往往十分庞大;而且无序数组的查找最坏情况需要遍历整个数组;后来人们提出了二分查

    2024年02月05日
    浏览(33)
  • 【Java数据结构 -- 队列:队列有关面试oj算法题】

    只允许在一端进行插入数据操作,在另一端进行删除数据操作得特殊线性表,队列是 先进先出 ,入队:进行插入操作得一端称为 队尾(rear) ,出队:进行删除操作的一端称为 队头(front) 。队列Queue是个接口, 底层通过链表实现的 。 boolean offer(E e) – 入队列 E poll() – 出队

    2024年01月25日
    浏览(36)
  • java八股文面试[数据结构]——HashMap扩容优化

         知识来源: 【2023年面试】HashMap在扩容上做了哪些优化_哔哩哔哩_bilibili  

    2024年02月11日
    浏览(31)
  • 【Java程序员面试专栏 数据结构】四 高频面试算法题:哈希表

    一轮的算法训练完成后,对相关的题目有了一个初步理解了,接下来进行专题训练,以下这些题目就是汇总的高频题目,一个O(1)查找的利器哈希表,所以放到一篇Blog中集中练习 题目 解题思路 时间 空间 两数之和 辅助哈希 使用map存储出现过的值,key为值大小,v

    2024年02月22日
    浏览(45)
  • java八股文面试[数据库]——MySQL索引的数据结构

    知识点: 【2023年面试】mysql索引的基本原理_哔哩哔哩_bilibili 【2023年面试】mysql索引结构有哪些,各自的优劣是什么_哔哩哔哩_bilibili

    2024年02月10日
    浏览(31)
  • java八股文面试[数据结构]——ArrayList和LinkedList区别

      ArrayList和LinkedList的异同 二者的线程都不安全,相对线程安全的Vector,执行效率高。此外,ArrayList时实现了基于动态数组的数据结构,LinkedList基于链表的数据结构,对于随机访问get和set,ArrayList觉得优于LinkedList比较占优势,因为LinledList要移动指针。对于新增和删除操作add

    2024年02月11日
    浏览(38)
  • 【Java集合类面试二十六】、介绍一下ArrayList的数据结构?

    文章底部有个人公众号: 热爱技术的小郑 。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。 面试官:介绍一下ArrayList的数据结构? 参考答案: ArrayList的底

    2024年02月08日
    浏览(34)
  • 扎实打牢数据结构算法根基,从此不怕算法面试系列之004 week01 02-04 使用泛型实现线性查找法

    在数组中逐个查找元素,即遍历。 在 扎实打牢数据结构算法根基,从此不怕算法面试系列之003 week01 02-03 代码实现线性查找法中,我们实现了如下代码: 之前实现的局限: 只支持int型。 需求: 支持所有的Java基本数据类型以及自定义的类类型。 很简单,很多语言都有这个处

    2023年04月16日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包