使用泛型问题调用Arrays.sort(数组,比较器)

时间:2011-05-24 22:57:42

标签: java generics

我正在尝试创建一个方法,而该方法又应该调用Arrays.sort方法,而我正在尝试将此方法作为通用本身。当我尝试创建一个具体的Comparator时,问题出现了,但我总是得到一个例外:

Generics.java:15: cannot find symbol
symbol  : method sort(java.lang.Comparable[],java.util.Comparator<T>)
location: class java.util.Arrays
                Arrays.sort(array,  c);
                      ^
1 error

我通过转换值来解决它,但我真的想知道如何正确编码它。

这是我的(相关)代码:

import java.util.*;
abstract class Generics<T1,T2> { 

  public abstract  void run( T1 a , T2 b );

  public static <T> void sort( Comparable[] array, final Generics<T,T> g  ) {

    Comparator<T> c = new Comparator<T>() {
      public int compare(T o1, T o2) {
        g.run(o1,o2);
        return 1;
      }
    };
    Arrays.sort(array, 
      /* how can I get rid of this cast? */ 
      (Comparator<? super Comparable>)
      /* and use only */ c);
  }

  public static void main( String ... args ) { 
    Generics.sort( args, new Generics<String,String>() { 
      public void run( String a, String b ) { 
        System.out.println( "Irrelevant");
      }
    });
  }
}

1 个答案:

答案 0 :(得分:6)

如果您想使用Comparable[],则您的方法不应传递T,而应传递Comparator<T>数组。

这样就这样定义:

public static <T extends Comparable<T>> void sort( T[] array, final Generics<T,T> g  ) {
    ...
}

但是你为什么要同时使用Comparable和Comparator?通常,想法是使用比较器或元素上的默认顺序(即可比较),但不能同时使用。