深入理解Java集合:如何使用for增强循环和泛型类型转换

因为集合中可以存储不同类型的值 ,所以集合记不住它们存储的类型 ,在取出来的时候都是Object类型,所以在用for增强循环时,需要进行类型转换,为了约束集合,我们可以使用泛型,规范存进去的值只能是某个引用数据类型

为什么for增强循环要进行强制转换:

为了访问它的属性或者方法。如果你需要访问 Student 特有的方法或字段(如 getName()),你必须将 Object 强制转换为 Student。这是因为 Object 类型没有 Student 类中定义的方法或字段。

在集合中不规定泛型类型:

创建集合时没有用泛型规定时,for循环括号内要使用Object类型,使用for增强循环时要强转。

java 复制代码
 List lists = new ArrayList();
        lists.add(student1);

         for (Object student : lists) {
            Student stu = (Student) student;
            System.out.println(stu);
        }

如果在集合中添加一个不是Student类型的数据,那么就会强转失败,报错

java 复制代码
 lists.add(12);

在集合中规定泛型类型:

在这里使用泛型规定了存入的数据类型,for循环括号内是String类型,就不需要在for增强循环中强转了,因为默认就是String对象,可以调用list的各种方法。

java 复制代码
        ArrayList<String> arrayList = new ArrayList<String>();
        arrayList.add("aa");
        arrayList.add("ab");
        arrayList.add("abc");
        for (String list:arrayList){
            System.out.println(list);
        }
        
        

其他1:为什么在for增强循环打印信息需要重写toString方法?

默认的 toString() 方法输出对象的类名哈希码,通常不具备实际意义。所以需要重写成输出内容的ToString方法。

重写ToString后及时不调用toString方法也可以正常输出信息,因为这是因为**println() 方法会自动调用对象的 toString() 方法。** 每当你使用 System.out.println() 打印一个对象时,Java 内部会隐式调用该对象的 toString() 方法来获取对象的字符串表示形式。因此,重写了 toString() 方法,println() 将使用你自定义的实现来输出对象信息。

其他2:泛型格式

java 复制代码
  ArrayList<String> arrayList = new ArrayList<String>();
java 复制代码
  ArrayList<String> arrayList = new ArrayList();

这两种形式有相同的效果

相关推荐
无限的鲜花22 分钟前
反射(原创推荐)
java·开发语言
IT二叔38 分钟前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
yongche_shi1 小时前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
一路向北he1 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
超级数据查看器1 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
AI行业学习2 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
折哥的程序人生 · 物流技术专研3 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai3 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
大圣编程3 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
硕风和炜3 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集