I'm trying to convert an AVLTree implementation into a heap style array and am having some problems with generics:
public class MyAVLTree<K extends Comparable<? super K>, E> implements
OrderedDictionary<K, E> {
class AVLNode implements Locator<K, E>{
// ...
}
// ....
public Locator<K,E> [] toBSTArray() {
AVLNode[] bArray = new AVLNode[size];
makeArray(root, 0, bArray); // recursion
return bArray;
}
}
At the line AVLNode[] bArray = new AVLNode[size];
I get the following error:
"Cannot create a generic array of MyAVLTree.AVLNode"
I don't see what I'm doing wrong. Any help?
Inner classes capture the type variables from an outer class so this is why you get the error.
If you wish to instantiate a raw AVLNode[]
you may qualify the class name as raw MyAVLTree
:
// vvvvvvvvv
AVLNode[] bArray = new MyAVLTree.AVLNode[size];
You will get warnings as you normally would creating a raw array type; however this will compile. Be advised the usual things that come along with raw types if you don't know them, although of course you cannot instantiate an array in Java that is not raw.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With