puede:
eliminar el parámetro <T>
tipo de TSTNode
(es decir, que sea no genérico): aún tendrá acceso al <T>
externo.
renombre el parámetro de tipo <T>
en la clase TSTNode
para (decir) U
.
[ACTUALIZACIÓN]
A continuación se presentan cuatro formas diferentes de reescribir el código. Todos compilan. Creo que deberías considerar el uso de un EnumMap
(mira la Versión 4, abajo).
Versión 1: utilice un parámetro de tipo con nombre diferente en la clase interna. necesita usar una lista en lugar de una matriz.
public class TernarySearchTree<T> {
protected class TSTNode<U> {
// index values for accessing relatives array:
protected static final int PARENT = 0, LOKID = 1, EQKID = 2, HIKID = 3;
protected char splitchar;
protected List<TSTNode<U>> relatives;
private U data;
protected TSTNode(char splitchar, TSTNode<U> parent) {
this.splitchar = splitchar;
relatives = new ArrayList<TSTNode<U>>();
for (int i = 0; i < HIKID; ++i) { // Allocate 4 slots in relatives
relatives.add(null);
}
relatives.set(PARENT, parent);
}
}
private TSTNode<T> node; // When you use it, pass T as U
public TernarySearchTree() {
node = new TSTNode<T>(',', null); // When you use it, pass T as U
}
}
Versión 2: heredar T de clase que lo contiene
public class TernarySearchTree<T> {
protected class TSTNode {
// index values for accessing relatives array:
protected static final int PARENT = 0, LOKID = 1, EQKID = 2, HIKID = 3;
protected char splitchar;
protected List<TSTNode> relatives;
private T data;
protected TSTNode(char splitchar, TSTNode parent) {
this.splitchar = splitchar;
relatives = new ArrayList<TSTNode>();
for (int i = 0; i < HIKID; ++i) { // Allocate 4 slots in relatives
relatives.add(null);
}
relatives.set(PARENT, parent);
}
}
private TSTNode node;
public TernarySearchTree() {
node = new TSTNode(',', null);
}
}
Versión 3: utilizar un mapa (en vez de una lista)
public class TernarySearchTree<T> {
protected class TSTNode {
// index values for accessing relatives array:
protected static final int PARENT = 0, LOKID = 1, EQKID = 2, HIKID = 3;
protected char splitchar;
protected Map<Integer, TSTNode> relatives;
private T data;
protected TSTNode(char splitchar, TSTNode parent) {
this.splitchar = splitchar;
// Create a hash map. No need to pre-allocate!
relatives = new HashMap<Integer, TSTNode>();
relatives.put(PARENT, parent); // set -> put
}
}
private TSTNode node;
public TernarySearchTree() {
node = new TSTNode(',', null);
}
}
}
versión 4: defina los índices como enum + use un EnunMap (en lugar de un hash ma p)
public class TernarySearchTree<T> {
protected static enum Index {
PARENT, LOKID, EQKID, HIKID;
}
protected class TSTNode {
protected char splitchar;
protected EnumMap<Index, TSTNode> relatives;
private T data;
protected TSTNode(char splitchar, TSTNode parent) {
this.splitchar = splitchar;
// Create an EnumMap.
relatives = new EnumMap<Index, TSTNode>(Index.class);
relatives.put(Index.PARENT, parent);
}
}
private TSTNode node;
public TernarySearchTree() {
node = new TSTNode(',', null);
}
}
[Actualización 2] Una cosa a tener en cuenta: Use EnumMap instead of ordinal indexing
Si obtiene un error de compilación, que debe incluir ** ** el error de compilación mensaje en tu pregunta! Pero funciona bien para mí. Solo asegúrate de deshacerte del '' en tu * declaration * of 'relatives' también. Dicho eso, siempre puedes hacer que 'TSTNode' sea estático y solo usar un parámetro diferente, como' E'. –
Por qué no es posible crear matrices genéricas: http://stackoverflow.com/questions/2927391/whats-the-reason-i-cant-create-generic-array-types-in-java –
¿Necesita TSTNode acceder campos de instancia o métodos de TernarySearchTree? –