草庐IT

java.lang.Class 泛型和通配符

为什么下面的代码编译不通过?interfaceIface{}classImplimplementsIface{}classTestCase{staticClass>clazz=Impl.class;}错误是java:incompatibletypes:java.lang.Classcannotbeconvertedtojava.lang.Class>但我不明白为什么通配符没有捕获。 最佳答案 这里的子类型关系是:Class╱╲Class>Class(我在对'CannotconvertfromListtoList>'的回答中对此进行了

Java 泛型 : Bound mismatch: The type is not a valid substitute for the bounded parameter of the type

我遇到了以下问题:我有这些类和接口(interface)定义publicabstractclassViewModelRefreshPostListFragment>extendsRefreshPostListFragmentimplementsIRefreshPostView{privatefinalViewModelHelpermViewModeHelper=//errorherenewViewModelHelper();...}publicabstractclassRefreshPostViewModelextendsAbstractViewModel{}publicclassVi

<T extends A<T>> 和 Inheritance 形式的 Java 泛型

我对Java泛型有一个棘手的问题,或者我可能只见树木不见森林。我有如下所示的三个类A、B和C。abstractclassA>{abstractTsefl();};abstractclassB>extendsA{};classCextendsB{@OverrideCsefl(){returnthis;}}后来我有不同版本的B,也有不同版本的C。此外,我有一个功能测试应该接受B的列表(或其表亲之一)。或者一般来说,它应该接受从A继承的任何元素列表。不幸的是,我需要知道函数主体中列表元素的类型,即最上面的类型a.self可以返回(或类型T)。功能测试如下:static>voidtest(Li

java - 如何声明具有多个具有重要关系的泛型类型的成员?

这是我想在我的java代码中写的内容:private,RextendsResult>MyTypemember;然而,这是无效的语法。所以我最后写:privateMyType,?extendsResult>member;但这忽略了从Result派生的两个类是相同的事实。我的类方法都强制执行这种关系,所以我可以确定MyType强制执行它,但在某些情况下我仍然必须不安全地类型转换member。更多详情这是我想要做的事情的精确版本,尽管它更加严格:我希望我能做到:private,RextendsResult>Map,ActionHandler>handlers;相反,我必须这样做:privat

java - 为什么这里不允许转换为 "GenericType<?>"?

此代码会导致javac出现编译错误(但值得注意的是,不会出现Eclipse4.2.2!):publicinterfaceFoo{}classBarimplementsFoo>{}classTest{voidtest(Foo>foo){Barbar=(Bar)foo;}}javac的错误是这样的:Foo.java:9:error:inconvertibletypesBarbar=(Bar)foo;^required:Barfound:FoowhereCAP#1isafreshtype-variable:CAP#1extendsIterablefromcaptureof?extendsIt

java - boolean containsAll(Collection<?> c) vs boolean addAll(Collection<? extends E> c); 的设计决策在集合框架中

这个问题在这里已经有了答案:GenericCollection(10个答案)关闭9年前。为什么booleancontainsAll(Collectionc);每种类型都允许集合框架的方法?。但是booleanaddAll(Collectionc);允许?extendsE。所以,我写了一个程序来澄清。这是我的程序publicclassContainAllTest{//takeServiceDtoArrayListresultList=newArrayList();voidTest(){ServiceDtoserviceDto=newServiceDto();serviceDto.setN

Java:创建一个简单的通用方法以在应用过滤器后进行计数

我想创建一个简单的通用方法来计算numbers根据提供的predicate应用过滤器后.staticintcount(Collectionnumbers,Predicatepredicate){returnnumbers.stream().filter(predicate).count();}它给我以下错误:incompatibletypes:PredicatecannotbeconvertedtoPredicatewhereCAP#1,CAP#2arefreshtype-variables:CAP#1extendsNumberfromcaptureof?extendsNumberCA

java - "? extends ParentClass"使只读?

在下面的Java代码中,我创建了一个列表nums。我可以在声明期间分配另一个列表。但是除了null之外不能添加新项目。那么,这是否意味着nums是只读的?为什么?是否可以在该列表中添加新项目?Listints=newArrayList();ints.add(1);ints.add(2);Listnums=ints;nums.add(3.14);//Generateserrornums.addAll(ints);//Generateserrornums.add(null);//worksSystem.out.println(nums.get(0));//works我已经完成了这个link

java - 为什么我们需要允许接口(interface)只从 java.lang.Object 而不是任何其他类扩展?

这个问题在这里已经有了答案:WhyObjectclassmethodsareavailableininterface?(5个答案)关闭7年前。AspermyunderstandingfromsomebooksonJava,interfacescannotextendclasses.ButallinterfacesdoinheritmethodsfromObjectclass.Whyisthisso?如果接口(interface)不是从对象类扩展的。那么这段代码是如何工作的呢?interfaceA{publicbooleanequals(Objecto);}classInterfaceA

java.util.Comparator.naturalOrder 采用 <T extends Comparable<? super T>> 并返回一个 Comparator<T> - 为什么?

(如果这是重复的,请指出正确的答案!我搜索并阅读了几个(>5)个相关问题,但似乎没有一个是正确的。还查看了泛型常见问题解答和其他来源...)当一个集合类接受一个比较器时,它应该具有Comparator类型显然是正确的做法。对于您的参数化类型T.你可以看到很多地方,例如TreeMap.好的。我的问题是使用Comparator.naturalOrder()在TextendsComparable上参数化但返回Comparator.我试图在我的集合类中有一个字段,它包含用户指定的比较器或Comparator.naturalOrder比较器。我无法让它工作。我的所有相关问题是:怎么样Compar