首页
学习
活动
专区
圈层
工具
发布

Java 泛型〈? extends T 〉和 〈? super T 〉

一、为什么要用通配符和边界? 使用泛型的过程中,经常出现一种很别扭的情况。 比如我们有Fruit类,和它的派生类Apple ?...但实际上Java编译器不允许这个操作。会报错,“装苹果的盘子”无法转换成“装水果的盘子”。 ?...extends T>和T>的办法,来让”水果盘子“和”苹果盘子“之间发生正当关系。 二、上界 下面就是上界通配符(Upper Bounds Wildcards) ?...再扩展一下,食物分成水果和肉类,水果有苹果和香蕉,肉类有猪肉和牛肉,苹果还有两种青苹果和红苹果。 ? 在这个体系中,上界通配符Plate覆盖下图中蓝色的区域。 ?...>和类型参数T>的区别就在于,对编译器来说所有的T都代表同一种类型。 比如下面这个泛型方法里,三个T都指代同一个类型,要么都是String,要么都是Integer... ? 但通配符<?

1.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java中<? extends T>和<? super T>的理解

    super T> 表示类型下界(Java Core中叫超类型限定),表示参数化类型是此类型的超类型(父类型),直至Object; 上界T>首先你很容易误解它为继承于T的所有类的集合,你可能认为,你定义的这个List可以用来put任何T的子类,那么我们看下面的代码: import java.util.LinkedList...list中为什么不能加入Father类和Father类的子类呢,我们来分析下。 List表示上限是Father,下面这样的赋值都是合法的 List和这个CAP#1匹配,所以就都不允许。 所以通配符和类型参数的区别就在于,对编译器来说所有的T都代表同一种类型。...而当我们读取的时候,编译器在不知道是什么类型的情况下只能返回Object对象,因为Object是任何Java类的最终祖先类。但这样的话,元素的类型信息就全部丢失了。

    1.5K10

    java泛型通配符 ? extends T 和 ? super T 的区别和用法

    https://www.cnblogs.com/chyu/p/4630798.html 关于Java泛型,这里我不想总结它是什么,这个百度一下一大堆解释,各种java的书籍中也有明确的定义,只要稍微看一下就能很快清楚....从泛型的英文名字Generic type也能看出,Generic普通、一般、通用的,是一个概括性的词,那么泛型从名字上也就好理解了,它是一种通用类型,是java中各种类型的概括. ?...是java泛型中的通配符,它代表java中的某一个类,那么就代表类型T的某个子类,就代表类型T的某个父类....那么 代表的是左侧小红苹果,红苹果和苹果的类中的某个类,而代表的就是苹果和水果,好吃的,吃的,的类中的某个类. 这里要注意的是或是代表的是范围内的某个特定的类,而不是范围内的所有类....因为对于有上限T,故我们如果list.get(0)一定返回的是T或是T的子类,这个是确定的,得出: List<?

    1.4K20

    在Java中,equals()和contains()谁更快

    在Java中,equals()和contains()方法的性能差异取决于具体场景,但通常equals()方法更快。以下是详细分析: 1....其底层通过indexOf()实现: 需要遍历原字符串的字符数组,逐字符与目标子串匹配,时间复杂度为O(n*m)(n为原字符串长度,m为子串长度)。...最差情况(完全匹配): 当两个字符串完全相同时,equals()需要逐个字符比较直至末尾,时间复杂度为 O(n) (n为字符串长度)。...此时,contains()若检查自身是否存在(如"apple".contains(“apple”)),其效率与equals()相近,但实际场景中此类用法较少。...结论 在大多数情况下,equals()方法比contains()更快,主要得益于其快速失败机制(如长度差异或早期字符不匹配)。

    34610

    在Java中Executor和Executors的区别?

    在Java中,Executor和Executors都与线程池和并发执行有关,但它们是不同的概念和类。...1.Executor  Executor是一个接口,位于java.util.concurrent包中,用于表示一个执行任务的执行器。...2.Executors  Executors是一个实用类,同样位于java.util.concurrent包中,它提供了一些工厂方法用于创建不同类型的线程池。...但是,它的一些默认线程池配置可能不适用于所有场景,特别是在处理大量任务时,可能需要更仔细地配置线程池参数以避免资源耗尽或性能问题。  ...在使用线程池时,根据实际情况,我们可以选择直接实现Executor接口来自定义执行策略,或者使用Executors类提供的预定义线程池来满足常见需求。

    22210

    在java中notify和notifyAll的区别

    但是当我们使用notifyAll的时候,多个线程得到了通知,但是线程的执行将逐个执行,因为线程中需要获得锁,而且一个对象只有要给锁可用。...何时使用notify和notifyAll 在互斥锁的情况下,只有一个等待的线程在受到通知之后可以做一些有用的事情,本例提到的获得锁,在这种情况下,你应该使用notify,如果真确实现的话,你也可以在这种情况下使用...notify和notifyAll应用 对共享资源的维护操作,其中多个线程在访问资源之前等待操作完成,对于这些,我们应该使用notifyAll。...我们希望在长进程完成的时候收到通知,你向要一个声音或者屏幕更新,进程执行notifyAll来通知声音程序和屏幕更新。...参考https://stackoverflow.com/questions/37026/java-notify-vs-notifyall-all-over-again

    1.3K31

    在Entity Framework 中执行T-sql语句

    从Entity Framework  4开始在ObjectContext对象上提供了2个方法可以直接执行SQL语句:ExecuteStoreQueryT> 和 ExecuteStoreCommand。...1、使用ExecuteStoreQueryT> :通过sql查询返回object实体,有有许多需要注意: 1.sql = "select * from Payment where Vendor= @vendor...2.如果sql语句返回的列少于(具体化)实体的属性的个数,那么EF在具体化的时候将抛出一个异常如下图,因此将需要缺少的列补上一些没有意义的值,以保证在具体乎的时候不会报错:eg 如图1,如果sql=”select...6.可以返回实体对象属性的子集,就是说如果对于Payment表,我们查询返回PaymentId和Amount字段,然后我们定义一个subPayment 实体包含PaymentId和Amount属性,然后使用...相关文章: Entity Framework 和 AppFabric 中的二级缓存 对Entity Framework应用二级缓存 Performance Considerations for Entity

    3.2K100

    Java中的Object、T(泛型)、?区别

    《Thinking in Java》中说很多原因促成了泛型的出现,最引人注目的一个原因就是为了创造容器类。这个要怎么来理解呢?...所以我们现在能小结一下Object和T很重要的两点区别就是: Object范围非常广,而T从一开始就会限定这个类型(包括它可以限定类型为Object)。...Object由于它是所有类的父类,所以会强制类型转换,而T从一开始在编码时(注意是在写代码时)就限定了某种具体类型,所以它不用强制类型转换。...(之所以要强调在写代码时是因为泛型在虚拟机中会被JVM擦除掉它的具体类型信息,这点可参考泛型,在这里不做引申)。 比如在jdk中的List类是个泛型类。...以上就是Object、T、?的区别。多写几行代码,多做试验,多讨论,就知道在何时何地恰当的使用了。

    2.4K100

    力扣题(2的幂)——学习到JAVA按位与“&”在“n&(n-1)”中的使用

    那么,(n & (n-1)) == 0是什么意思呢 java中“&”表示按位与操作,他把左右变为二进制然后按位取与。 “n=n&(n-1)”的意思就是 去掉“n的二进制”的最后一个1....如果A&B==0,表示A与B的二进制形式没有在同一个位置都为1的时候。 这句话到底啥意思??不妨先看下n-1是什么意思。...n&(n-1)=1101010000 由此可以得出,n和n-1的低位不一样,直到有个转折点,就是借位的那个点,从这个点开始的高位,n和n-1都一样,如果高位一样这就造成一个问题,就是n和n-1在相同的位上可能会有同一个...1,从而使((n & (n-1)) !...= 0),如果想要 ((n & (n-1)) == 0),则高位必须全为0,这样就没有相同的1。 所以n是2的幂或0

    85140

    Java 中拼接 String 的 N 种方式

    在这篇文章中,将介绍一些在拼接 String 时避免 null 值的几种方式。 2....同样,即使我们在 Java 8 或更高版本上运行,然后使用String.join() 静态方法拼接字符串,一样会得到带有 null 值的输出。...使用 StringJoiner 类 (Java 8+) StringJoiner 类提供了更强大的字符串拼接功能,不仅可以指定拼接时的分隔符,还可以指定拼接时的前缀和后缀,这里我们可以使用它的 add(...使用 Streams.filter (Java 8+) Stream API 是 Java 8 引入的功能强大的流式操作类,可以进行常见的过滤、映射、遍历、分组、统计等操作。...filter 可以接收一个 Predicate 函数,Predicate 函数接口同之前介绍的 Function (opens new window)接口一样,是一个函数式接口,它可以接受一个泛型 T>

    1.2K20

    java注解及在butternife中的实践和原理

    背景 之前去一个公司,说到了java的注解,问java的注解有几种方式,然后我提到了android中的butternife和afinal注解工具,我们知道butternife在6.1版本的时候还是InjectView...JDK5.0注解可以看成是Javadoc标签和Xdoclet标签的延伸和发展。在JDK5.0中,我们可以自定义这些标签,并通过Java语言的反射机制中获取类中标注的注解,完成特定的功能。...注解的语法比较简单,除了@符号的使用以外,它基本上与java的固有语法一致,java内置了三种注解,定义在java.lang包中。...d)   如果注解只有一个成员,则成员名必须取名为value(),在使用时可以忽略成员名和赋值号(=),如@Description("使用注解的实例")。...Ø  RetentionPolicy.CLASS 注解在class文件中可用,但会被VM丢弃。

    92850
    领券