草庐IT

custom-compare

全部标签

java - Long 类型未定义方法 compare(long, long)

我需要制作一个Comparator来根据它的long类型的变量之一对我的对象列表进行排序。publicclassParticipantIndexComparatorimplementsComparator{finalListparticipants;publicParticipantIndexComparator(ArrayListnumbersToSort){participants=newArrayList();for(inti=0;i但是returnLong.compare(l1,l2);无效-“方法compare(long,long)未定义Long类型”。看来我做错了。

java - Comparator<String> 必须覆盖父类(super class)方法

我正在制作TreeMap并希望以降序排列。我创建了以下比较器:Comparatordescender=newComparator(){@Overridepublicintcompare(Stringo1,Stringo2){returno2.compareTo(o1);}};我像这样构建TreeMap:myMap=newTreeMap(descender);但是,我收到以下错误:Themethodcompare(String,String)oftypenewComparator(){}mustoverrideasuperclassmethod我从来没有完全理解泛型,我做错了什么?

java "not comparable"异常?

我正在制作一个实现可比性的自定义类,如果有人试图比较两个根据我的定义不可比的对象,我想抛出某种异常。API中是否已有合适的异常,还是我需要自己创建? 最佳答案 据我所知不是。最准确的异常表示可能是IllegalArgumentException:http://docs.oracle.com/javase/7/docs/api/java/lang/IllegalArgumentException.html您可能还应该实现Comparable这将防止调用者提供错误类的实例。 关于java"n

Java 8 : How to compare all elements of a Set

这可能是一个已经问过的问题,但我找不到我需要的答案。我有一个包含对象的集合publicclassMyObject{privateLocalDatedateBeginning;privateLocalDatedateEnd;publicbooleanoverlap(MyObjectotherDate){/*codetocheckoverlapping*/}}我需要检查Set是否包含相互重叠的元素。在“旧Java”中,我会遍历该集合两次并检查所有存在的组合,然后在找到它时中断或返回。我们如何在Java8中使用流和lambda来做到这一点?我已经尝试过reduction()和filter()

java - Java 8's HashMap misbehaves if the keys implement Comparable in a way that isn' t 与equals一致是不是bug?

我知道从Java8开始,如果HashMap有足够多的哈希冲突,并且键实现了Comparable,它会useabalancedtreeinsteadofalinkedlistforthebin.但据我所知,Comparable接口(interface)doesnotrequirecompareTo()应“与equals()一致”(尽管强烈建议这样做)。我错过了什么吗?似乎新的实现允许HashMap违反Map接口(interface)的要求,如果键恰好具有兼容但不推荐的Comparable实现。以下JUnit测试在OpenJDK8u72上暴露了此行为:importstaticorg.jun

java - 为什么 Temporal 不在 Java 8 jsr310 中扩展 Comparable

java.time.temporal.Temporal的文档包含以下说明:ImplementationRequirements:[...]AllimplementationsmustbeComparable.为什么Temporal不只是扩展Comparable?背景:我想使用可比较的时间(而不是像LocalDateTime等子类型)并且不得不求助于一种有点难以辨认的类型>这也搞乱了NetBeans的自动完成功能。编辑:我想实现一个时间间隔。contains(Intervali)、contains(Temporalt)、overlaps(...)、adjoins(...)等的明显实现使用

java - Comparator 是类型类吗?

我一直在阅读Scala中的类型类,并认为我已经很好地掌握了它,直到我想起了Java的java.util.Comparator。如果我理解正确的话,Ordering是类型类的原型(prototype)示例。我能想到的Comparator和Ordering实例之间的唯一区别是比较器必须是显式的,而排序可以而且通常是隐式的。Comparator是类型类吗?我得到(错误的?)印象,即Java实际上没有类型类。这是否意味着类型类需要能够是隐式的?我认为类型类的隐式转换主要是语法糖-尽管它很棒,但它“只是”给了编译器足够的提示-我是不是遗漏了什么?下面的代码示例展示了Comparator如何向没有

java - 映射结构 : enrich mapping annotation to define custom mapper

这是我的上下文:我正在使用byteBuddy动态生成一个类,该类根据外部配置将一个对象转换为另一个对象。我遇到了一些问题,我想找到一个替代方案,这就是我发现MapStruct的方式。所以我尝试构建简单的映射器,我想知道是否可以自定义注释以添加转换功能。例如我想要:@Mapping(source="mySourceField",sourceType="String",target="myTargetField",targetType="Integer",transformation={"toInteger","toSquare"}),在映射器实现上我会有类似的东西:publicTypeD

css - "safe"Angular 2 自定义 html 标签如何? (选择器 : Custom tags vs. 自定义属性)

这是一个关于Angular2选择器、自定义标签与自定义属性、搜索引擎优化和浏览器渲染的问题。当我第一次开始查看Angular2时,我按照他们的快速入门所做的第一件事就是将我的选择器更改为'[my-component]'(属性选择器)而不是'my-component'(标签选择器),所以我可以有在我的html中而不是,这不是有效的html。所以我会根据标准编写html。好吧,至少非常接近标准(因为my-component不是有效的html属性,但我只能忍受该html验证错误)然后,在youtube上的某个视频中,angular团队的某个人提到我们应该使用标签选择器,至少在性能方面是明智的

c++ - 法线贴图 : TBN matrix different result in vertex shader compared to fragment shader

我正在为教程开发法线贴图实现,出于教学目的,我想将TBN矩阵传递给片段着色器(从顶点着色器),这样我就可以将切线空间中的法线vector转换为世界-照明计算的空间。法线贴图应用于二维平面,其法线指向正z方向。但是,当我在平面的顶点着色器中计算TBN矩阵时(因此所有顶点的所有切线/副切线都相同),显示的法线完全关闭。如果我将切线/副切线和法线vector传递给片段着色器并在那里构造TBN,它工作得很好,如下图所示(显示法线):这就是奇怪的地方。因为平面是平坦的,所以它的所有顶点的T、B和Nvector都相同,因此每个片段的TBN矩阵也应该相同(因为片段插值不会改变任何东西)。顶点着色器中