news 2026/4/23 15:28:22

Java 泛型中的通配符 T,E,K,V,?有去搞清楚吗?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java 泛型中的通配符 T,E,K,V,?有去搞清楚吗?

Java 泛型中的 T、E、K、V、?到底啥意思?

——2025 年了,还在懵?看完这张表直接秒懂,再也不被面试官吊打

符号官方/社区约定含义最常见出现场景真实项目里谁在用(2025 年真实案例)能不能随便换?
TType(任意类型)类泛型定义最通用写法class Cache<T>
public <T> T get(String key)
99% 的自定义泛型类/方法
EElement(集合元素) 集合框架专用List<E>Set<E>Map.Entry<K,V>JDK 源码、所有集合类只能用于集合相关,换了会被打
KKey(键) Map 的 keyMap<K,V>Cache<K,V>所有 Map、缓存、配置中心只能表示 key,换了就乱套
VValue(值) Map 的 valueMap<K,V>Result<V>所有返回值、缓存 value同上
?Unknown(未知类型) 通配符,表示“任意类型”List<?>Comparator<? super T>工具类、兼容老代码、泛型擦除场景不能在定义泛型时用,只能用在“使用”时
NNumber(数字) 数字相关List<N extends Number>数字工具类很少用
RReturn Type(返回值类型) 函数式编程常用<R> R map(Function<T,R> mapper)Stream、Optional、CompletableFuture越来越流行
SU第二、第三个类型参数 多泛型参数时用<S,U> BiFunction<T,S,U>函数式接口、复杂工具类很少见

2025 年真实项目写法排行(大厂规范)

排名写法示例谁在用?为什么这么写?
1public class Result<T>所有中大型项目返回包装类T 代表任意业务数据
2public interface Repository<T, ID>Spring Data JPA 规范T=实体,ID=主键类型
3Map<String, Object>99% 的项目(虽然不规范)懒得定义 VO
4PageResult<List<T>>所有分页接口外层是包装,内层是具体类型
5<T> T getBean(Class<T> clazz)Spring 工具类返回值类型由调用方决定
6List<? extends User>协变:只能读,不能加PECS 原则
7List<? super Admin>逆变:只能写,不能读生产者用 extends,消费者用 super

面试官最爱问的 5 个灵魂问题 + 标准答案

问题标准答案(背下来)
T 和 ? 的区别?T 是类型占位符,必须在定义时声明;? 是通配符,使用时才出现,表示未知类型,不能加元素(只能 get)
为什么 Map 用 K,V 而不是 T?因为有明确语义:Key 和 Value,阅读性强,IDE 提示更友好
List<? extends Animal>能 add(null) 吗?能 add(null),但不能 add 任何 Animal 子类,因为编译器不知道具体类型
Comparator<? super T>是什么意思?比较器可以接受 T 或 T 的父类,用于逆变,经典例子:Collections.sort()
为什么 Spring 用 里不写类型?泛型推导(Diamond Operator),JDK7+ 特性,编译器自动推断

2025 年最正确的写法(直接抄作业)

// 推荐:语义清晰publicclassCache<K,V>{...}publicclassResult<T>process(Tinput){...}public<R>PageResult<R>query(PageQueryquery,Class<R>clazz){...}// 不推荐:虽然能跑,但会被架构师打publicclassCache<T,V>{...}// K 改成 T?别闹public<T>TdoSomething(){...}// 随便用 T,阅读者一脸懵List<?>list=newArrayList<>();// 完全不知道里面是什么

终极结论(2025 年面试/写代码必背)

“T = Type(万能)
E = Element(集合专属)
K V = Key Value(Map 专属)
? = 不知道,但肯定是某种类型(通配符)

记住这句口诀:
“定义用 T,集合 E,Map 永远 K 和 V,读多写少 extends,写多读少 super,啥也不知道问号 ?”

你现在项目里,有没有把 Map 写成 Map<T, V> 的?
敢不敢贴出来让我帮你改成 K,V,顺便升个级?来!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:49:21

专业创作新选择:2025年AI写作软件哪家好?详解蜜度模力通

当前&#xff0c;AI与日常工作的结合已愈发紧密。在文字创作领域&#xff0c;各类AI写作软件层出不穷&#xff0c;但能力的边界与专精度却大相径庭。对于追求内容精准、格式规范、流程合规的专业写作场景&#xff0c;尤其是公文撰写&#xff0c;泛用的创作工具往往力有不逮。那…

作者头像 李华
网站建设 2026/4/23 14:54:37

抗辐射光纤介绍

抗辐射光纤是一种能够在强辐射环境下保持良好性能的特殊光纤&#xff0c;以下是关于它的详细介绍&#xff1a;原理材料选择&#xff1a;抗辐射光纤通常采用纯石英或掺锗石英等材料作为纤芯和包层。这些材料具有较好的抗辐射性能&#xff0c;因为它们的原子结构相对稳定&#xf…

作者头像 李华
网站建设 2026/4/23 12:47:03

40亿参数端侧突围:GLM-Edge-4B-Chat开启智能终端新范式

40亿参数端侧突围&#xff1a;GLM-Edge-4B-Chat开启智能终端新范式 【免费下载链接】glm-edge-4b-chat 项目地址: https://ai.gitcode.com/zai-org/glm-edge-4b-chat 导语 智谱AI最新发布的GLM-Edge-4B-Chat轻量化模型&#xff0c;以40亿参数实现消费级设备本地部署&a…

作者头像 李华
网站建设 2026/4/23 13:32:06

终极人脸识别解决方案:Double Take完整使用指南

在人工智能技术飞速发展的今天&#xff0c;人脸识别已成为智能安防、社交应用、智能家居等领域的核心技术。然而&#xff0c;面对市面上众多的人脸识别引擎&#xff0c;如何选择和管理成为了用户面临的一大难题。Double Take应运而生&#xff0c;这个开源项目通过统一的UI界面和…

作者头像 李华
网站建设 2026/4/23 15:02:05

15、定制Knoppix Live CD全攻略

定制Knoppix Live CD全攻略 1. 制作Live CD的项目工具 在制作Live CD时,有两个项目提供了用于运行修改版安装程序以生成Live CD ISO镜像的工具: - Fedora Kadischi项目(搭配anaconda) :使用Fedora同名项目的 kadischi 命令,可启动一个流程,该流程会调用Fedora安装…

作者头像 李华