热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JAVA对象的容器《JAVA编程思想》03

在编程中,我们常常需要引用多个相同的对象,但在解决特定问题时往往不知道需要生成多少个对象?它们需要存储多久?该如何存储这些对

在编程中,我们常常需要引用多个相同的对象,但在解决特定问题时往往不知道需要生成多少个对象?它们需要存储多久?该如何存储这些对象?

在大多数数语言中都可以通过数组类型来实现这一需求,这类数组通常被称作为容器(也被成为集合)。容器自身会进行扩充,编程者不必在意会有多少个对象需要存储,只需要创建容器对象,然后让其帮你处理所有细节。

JAVA中常见的容器分为三类:

1.List
List用于存储序列,常见的导出类为ArrayList和LinkedList,它们都实现了List的接口。在ArrayList中,随机访问元素花费的时间是固定的,但往中间插入元素,开销会比LinkedList大;LinkedList随机访问元素的代价高昂,但随机插入元素的性能优异。

2.Map
Map被称为关联数组,用过存储键值对的形式,来建立对象之间的关联。

3.Set
存储的对象不会重复,常用于去重的场景。

除此之外还有队列、树、堆栈等构件,适用于不同的存储场景。

JAVA容器中存储的对象默认为Object类型,因其为单根继承结构,故所有对象都可以向上转型为Object对象,可以存储Object的容器便可以存储任意对象。

但对象向上转型,会使它丢失身份,当我们从容器中取回对象时,就获取了一个对Object类型的引用,这时就需要一个接口在获取对象时能够转为具体引用对象,这里需要用到向下转型,将需要获取的对象指定为泛型,用一对尖括号表示。

List shapeList &#61; new ArrayList<>();

向下转型通常是不安全的&#xff08;如&#xff1a;正方形可以向上转型为几何形&#xff0c;但几何形向下转型不一定为正方形&#xff0c;它还有可能是圆形&#xff09;&#xff0c;故向下转型时需要程序员付出更多心血去思考&#xff0c;避免程序出错。

这里顺带一提JAVA的异常处理机制&#xff0c;异常处理依赖于程序员的警惕性&#xff0c;异常是一种对象&#xff0c;它从出错地点被“抛出”&#xff0c;并被相应的异常处理器“捕获”。异常处理就像是程序在正常路径发生错误时&#xff0c;执行另一条路径&#xff0c;从而不影响后续程序的正常运行。

在对象的使用中&#xff0c;我们还有一个不可忽视的问题&#xff1a;对象的生成与销毁。

每个对象为了生存都需要占用内存资源&#xff0c;当我们不再需要一个对象时&#xff0c;它必须被清理掉&#xff0c;使其被占用的资源被释放&#xff0c;否则易发生内存泄露

在C&#43;&#43;中&#xff0c;对象的生命周期是由程序员直接控制&#xff0c;这种方式将存储空间的分配和释放置于优先考虑的位置&#xff0c;必须在编写程序时知道对象的确切数量、生命周期和类型&#xff0c;这会使得问题变得复杂&#xff0c;牺牲了灵活性&#xff0c;但这也是为了追求最大的执行速度做出的牺牲。

JAVA采用动态内存分配方式&#xff0c;每当创建新对象时&#xff0c;就使用new关键字来进行构建&#xff0c;这种方式直到运行时才知道需要多少对象&#xff0c;对象在堆中创建&#xff0c;存储空间在运行时被动态管理&#xff0c;程序员不必关心对象会在何时会被释放&#xff0c;JAVA中的“垃圾回收器”可以自动发现不在使用的对象&#xff0c;并将其销毁&#xff0c;减少了编程时需要考虑的问题&#xff0c;可以避免暗藏的内存泄露&#xff0c;这也得益于JAVA对象都是源于Object的单根继承结构&#xff0c;简化了“垃圾回收器”的实现。

本次分享至此结束&#xff0c;希望本文对你有所帮助&#xff0c;若能点亮下方的点赞按钮&#xff0c;在下感激不尽&#xff0c;谢谢您的【精神支持】。

若有任何疑问&#xff0c;也欢迎与我交流&#xff0c;若存在不足之处&#xff0c;也欢迎各位指正&#xff01;


推荐阅读
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文探讨了C语言中指针的应用与价值,指针在C语言中具有灵活性和可变性,通过指针可以操作系统内存和控制外部I/O端口。文章介绍了指针变量和指针的指向变量的含义和用法,以及判断变量数据类型和指向变量或成员变量的类型的方法。还讨论了指针访问数组元素和下标法数组元素的等价关系,以及指针作为函数参数可以改变主调函数变量的值的特点。此外,文章还提到了指针在动态存储分配、链表创建和相关操作中的应用,以及类成员指针与外部变量的区分方法。通过本文的阐述,读者可以更好地理解和应用C语言中的指针。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文介绍了Java的公式汇总及相关知识,包括定义变量的语法格式、类型转换公式、三元表达式、定义新的实例的格式、引用类型的方法以及数组静态初始化等内容。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • Java和JavaScript是什么关系?java跟javaScript都是编程语言,只是java跟javaScript没有什么太大关系,一个是脚本语言(前端语言),一个是面向对象 ... [详细]
author-avatar
黄家驹1994
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有