Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Java Generics: Cannot create an array of a nested class

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?

like image 579
user66875 Avatar asked Oct 19 '22 22:10

user66875


1 Answers

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.

like image 88
Radiodef Avatar answered Oct 26 '22 23:10

Radiodef