0

您好需要有关 java 集合排序的帮助。它给了我这个错误:

Bound mismatch: The generic method sort(List<T>) of type Collections is not applicable for the arguments (List<WifiSSID>). 
The inferred type WifiSSID is not a valid substitute for the bounded parameter <T extends Comparable<? super T>>

我的代码如下所示:

public class WifiSSID {

    public String SSIS;
    public double id;
}


 public class ScanFilterWifiList {

    public ScanFilterWifiList(List<WifiSSID> wifiList) {
        Collections.sort(wifiList);
           //Collections.sort(wifiList, new SortSSIDByid()); tried this also.
    }
}
interface Comparator<WifiSSID>
{
    int compare(WifiSSID obj1, WifiSSID obj2);
}

class SortSSIDByid implements Comparator<WifiSSID>
{
    @Override
    public int compare(WifiSSID ssid1, WifiSSID ssid2) 
    {
        int value = 0; 
        if (ssid1.id > ssid2.id) 
            value = 1; 
        else if (ssid1.id < ssid2.id) 
            value = -1; 
        else if (ssid1.id == ssid2.id) 
            value = 0; 
        return value; 
     }
}

我做错什么了吗?

4

2 回答 2

4

您无法对未实现该Comparable接口的对象列表进行排序。或者更确切地说,你可以,但你必须提供一个Comparator方法Collections.sort()

想一想:如何Collections.sort()在不知道 WifiSSID 何时小于或大于另一个的情况下对列表进行排序?

你想用Collections.sort(wifiList, new SortSSIDByid());

编辑:

您定义了自己的专有Comparator接口,并在SortSSIDByid. Collections.sort()想要一个java.util.Comparator. 不是您的专有 Comparator 接口的实例,它不知道。

于 2013-10-05T10:01:27.687 回答
1

只需添加此导入import java.util.Comparator;

并删除此接口

interface Comparator<WifiSSID>
{
    int compare(WifiSSID obj1, WifiSSID obj2);
}

您的SortSSIDByid比较器类现在将实现java.util.Comparator,这就是该Collections.sort()方法所需要的。

于 2013-10-05T10:18:21.977 回答