ラムダ式でオブジェクトの型指定された配列をソートします

takesuma:

私は理解していないという問題に遭遇します。テーブルクラスに添加する方法では私が使用したいと思います:

Arrays.binarySearch(asso, (a,b) -> a.cle.compareTo(b.cle));

ASSOは、協会の私の配列は、キーと値を含むオブジェクトです。

String型でこのコードを実行することにより、私はエラーがメソッドのcompareTo(Object)を上の「シンボルを見つけることができません」を取得します。

そこに私のコード:

テスト:

Table<String,String> table0 = new Table<String,String>(10);
table0.add("1","int");

方法:

import java.util.Arrays;

public class Table<C,V>{

  Association[] asso;

  public Table(int n){
    asso = new Association[n];
  }

  public void add(C cle, V valeur){
    asso[0] = new Association<C,V>(cle,valeur);
    Arrays.sort(asso, (a,b) -> a.cle.compareTo(b.cle));
  }

  public class Association<C,V>{

    public C cle;
    public V valeur;

    public Association(C cle,V valeur){
      this.cle = cle;
      this.valeur = valeur;
    }
  }
}

そして、エラー:

../src/Table.java:15: error: cannot find symbol
Arrays.sort(asso, (a,b) -> a.cle.compareTo(b.cle));
                                ^
symbol:   method compareTo(Object)
location: variable cle of type C
where C is a type-variable:
C extends Object declared in class Table.Association

ご協力ありがとうございました。

彼らは次のとおりでした:

ジェネリック型パラメータにバインドタイプを追加しますC

class Table<C extends Comparable<C>,V>

そうしないと、コンパイラは、その知らないC道具をComparable(したがって、持っている必要がありますcompareTo方法を)。

また、生タイプ(使用していないAssociation[]配列のために)。使用する:

Association<C,V>[] asso;

考え直しで、私はまた、あなたが作る提案するAssociationクラスをstatic

public class Table<C extends Comparable<C>,V> {

    Association<C,V>[] asso;

    public Table(int n) {
        asso = new Association[n];
    }

    public void add(C cle, V valeur) {
        asso[0] = new Association<C,V>(cle,valeur);
        Arrays.sort(asso, (a,b) -> a.cle.compareTo(b.cle));
    }

    public static class Association<C,V> {

        public C cle;
        public V valeur;

        public Association(C cle,V valeur){
            this.cle = cle;
            this.valeur = valeur;
        }
    }
}

おすすめ

転載: http://43.154.161.224:23101/article/api/json?id=189001&siteId=1