- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
尝试使用比较器对数组进行二分搜索时,出现奇怪的错误。该错误指出“compareArtist 无法解析为类型”,并由 Eclipse 在此代码上抛出:
Comparator<Song> compare = new Song.compareArtist();
我做了一些搜索,发现了 Eclipse 可能存在的错误,尽管我在另一台计算机上尝试过代码并且错误仍然存在。
我还发现了有关比较方法(在本例中为compareArtist)大小写的类似问题。我见过方法名称中的第一个单词大写的示例,尽管我的理解是方法名称传统上以小写字母开头。我尝试过更改大小写,但没有任何改变。
如果类没有导入正确的包,我还发现了对此错误的引用。我已在相关的两个类中导入了 java.util,据我所知,这允许使用比较器。
我已经尝试在具有二分搜索调用的类以及“Song”类中编写compareArtist方法,根据我的家庭作业,它应该在它应该在的位置。我已相应地更改了构造函数,但问题仍然存在。
最后,我尝试通过在 Song 类中实现 Comparator 并创建我自己的名为“compare”的方法来重写 Comparator 比较方法。这会返回相同的错误。在找到几个具有相同功能的示例后,我才开始调用与“compare”不同的比较器方法。
下面是调用使用比较器的二分搜索的类的相关代码。此代码还有一个本地版本的compareArtist 方法。虽然当前尚未调用该方法,但该方法的代码与我尝试从中调用它的 Song 类中的代码相同。
感谢您的建议和见解。
import java.io.*;
import java.util.*;
public class SearchByArtistPrefix {
private Song[] songs; // keep a direct reference to the song array
private Song[] searchResults; // holds the results of the search
private ArrayList<Song> searchList = new ArrayList<Song>(); // hold results of search while being populated. Converted to searchResults array.
public SearchByArtistPrefix(SongCollection sc) {
songs = sc.getAllSongs();
}
public int compareArtist (Song firstSong, Song secondSong) {
return firstSong.getArtist().compareTo(secondSong.getArtist());
}
public Song[] search(String artistPrefix) {
String artistInput = artistPrefix;
int searchLength = artistInput.length();
Song searchSong = new Song(artistInput, "", "");
Comparator<Song> compare = new Song.compareArtist();
int search = Arrays.binarySearch(songs, searchSong, compare);
歌曲类代码:
import java.io.FileNotFoundException;
import java.util.*;
public class Song implements Comparable<Song> {
private String artist, title, lyrics;
private static int compareCounter = 0;
public Song(String artistName, String songTitle, String songLyrics) {
this.artist = artistName;
this.title = songTitle;
this.lyrics = songLyrics;
}
public String getArtist() {
return artist;
}
public void setArtist(String artist) {
this.artist = artist;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getLyrics() {
return lyrics;
}
public void setLyrics(String lyrics) {
this.lyrics = lyrics;
}
public static int getCounter() {
return compareCounter;
}
public static void setCounter(int compareCounter) {
Song.compareCounter = compareCounter;
}
public int compareTo(Song secondSong) {
String secondArtist = secondSong.getArtist();
String secondTitle = secondSong.getTitle();
compareCounter++;
if (!this.artist.equals(secondArtist)) {
return this.artist.compareToIgnoreCase(secondArtist);
} else {
return this.title.compareToIgnoreCase(secondTitle);
}
}
public int compareArtist (Song firstSong, Song secondSong) {
return firstSong.getArtist().compareTo(secondSong.getArtist());
}
类末尾还有一个 main() 方法,但它仅提供内部测试代码,与当前问题无关。
最佳答案
在此代码中:
Comparator<Song> compare = new Song.compareArtist();
您正在从 Song.compareArtist
静态内部类实例化。此错误消息表明找不到此类。为此,您必须按以下方式更改您的 Song 类:
class Song{
public static class compareArtist<T> implements Comparator<T> {
@Override
public int compare(Object o1, Object o2) {
// TODO Auto-generated method stub
return 0;
}
}
}
关于Java "compare cannot be resolved to a type"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12575833/
我经常有一个 Comparator 类型,而我需要一个 Comparable 类型,反之亦然。是否有可重用的 JDK API 可以相互转换?类似的东西: public static Comp
我怎么能写这个 Comparator sort = (i1, i2) -> Boolean.compare(i2.isOpen(), i1.isOpen()); 像这样(代码不起作用): Compa
请帮助她。我有一个错误 Collections.sort(var4, new Comparator() { public int compare(TreeMap var1, TreeMa
学习 Kotlin,我试图了解 Java 的 Comparator接口(interface)有效 - 主要是 compare() 函数,这样我就可以利用它。 我已经尝试阅读 compare() 的文档
我有以下程序 List numbers = Arrays.asList("10", "68", "97", "9", "21", "12"); Collections.sort(numbers, (
我想根据嵌套类的属性对如下所示的列表进行排序。 class Test { private NestedClass nestedClass; private AnotherNes
我很好奇“Beyond Compare”的算法是如何工作的? 我猜想他们使用了一种标准的(众所周知的?)算法来实现“字符与字符”的比较。你知道这个算法的名字吗?谢谢 最佳答案 Beyond Compa
这个问题已经有答案了: How does the sort() method of the Collection class call the Comparable's compareTo()? (1
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicates: difference between compare() and compareTo() Java: What i
我被要求为某个类实现Comparable或Compartor,我们称之为V。 假设我有一个 V 的 Collection 或 Set(还不确定,但我认为这并不重要)。 V 有一个方法,可以评估它的“权
我正在查看Java8中实现的Comparator.comparing方法的源代码 这是代码 public static Comparator comparing( Function
假设我有一个类 ClassA,它的属性是 ClassB: public ClassA { private String attr; private ClassB classB; } p
我有一个自定义比较器,其比较逻辑如下: List l = new ArrayList(); l.add("tendercoupon"); l.add("giftcard
我正在努力实现一个处理 Comparator 和 Comparable 接口(interface)的层次结构。我不清楚的几件事: 如果我将比较器添加到比较器链中,这段代码究竟意味着什么 chain.a
正在关注 this question关于按另一个列表对列表进行排序,我尝试做同样的事情 - 但由于某种原因它对我不起作用。我错过了什么? List nums = Arrays.asList(5
假设我有一个像这样的领域模型: class Lecture { Course course; ... // getters } class Course { Teache
在表达式 > 中像这样的签名 public static > foo(T x) { ... } T的描述递归地依赖于Comparable . 如果T延伸Comparable ,和Comparable延
所有“数字”比较器(例如 Comparer.Default 、 Comparer.Default 等)返回 -1 的原因是什么? , 0或 1 ,但是 Comparer.Default和 Compar
(如果这是重复的,请指出正确的答案!我搜索并阅读了几个(> 5)个相关问题,但似乎没有一个是正确的。还查看了泛型常见问题解答和其他来源...) 当一个集合类接受一个比较器时,它应该具有 Compara
SBCL 1.3.1 综上所述,a是一个列表,'(7),b通过setq sbcl This is SBCL 1.3.1.debian, an implementation of ANSI Common
我是一名优秀的程序员,十分优秀!