Is not accessible in current context

后端 未结 4 1162
猫巷女王i
猫巷女王i 2021-02-05 04:58

I have the following code

public abstract class BaseAdapter extends ArrayAdapter {
    public BaseAdapter(Con         


        
相关标签:
4条回答
  • 2021-02-05 05:32

    I faced this issue before, I'm not sure why that happened, but I resolved it by making the not-accessible inner class a stand-alone class (not inner means in a separate file).

    0 讨论(0)
  • 2021-02-05 05:40

    Happened the same to me when extending a Base class. But this time I had it like this (following the given example in the question)

    BaseAdapter.java

    public abstract class BaseAdapter<T, V extends BaseAdapter.ViewHolder> extends ArrayAdapter<T> {
        public BaseAdapter(Context context, int resource, Collection<T> collection) {
            // typical constructor logic
        }
    
        // some other custom defined methods
    
        public static class ViewHolder {
            // custom defined logic
        }
    }
    

    ModelAdapter.java

    import com.mypackage.ModelAdapter.ModelViewHolder; ***//NOTE THIS IMPORT!!!***
    
    public class ModelAdapter extends BaseAdapter<Model, ModelAdapter.ModelViewHolder> {
        public ModelAdapter(Context context, int resource, Collection<Model> collection) {
           super(context, resource, collection);
           // typical constructor logic
        }
    
        public static class ModelViewHolder extends ViewHolder {
            // custom defined logic
        }
    }
    

    That way the warning was gone and didnt need to separate ModelViewHolder into another '.java' file. Notice that they are in two different files and the import in ModelAdapter.java.

    I think Fei Liang's answer is partially incorrect because being ModelViewHolder static should make possible to initialize ModelViewHolder without initializing its parent class ModelAdapter

    0 讨论(0)
  • 2021-02-05 05:47

    Creation Dead Lock

    You use ModelAdapter.ModelViewHolder as the template parameter of BaseAdapter, and let ModelAdapter extends BaseAdapter, then the compiler tried to create ModelViewHolder first, but the class of ModelAdapter.ModelViewHolder(the type is Class) is not yet created. It must wait for ModelAdapter to be created, because ModelViewHolder is in the scope of ModelAdapter.

    The way to solve it is put the ModelViewHolder class into a new *.java file.

    0 讨论(0)
  • 2021-02-05 05:51

    Here's how it got resolved for me. Generally there shouldn't be a circular dependency problem, as the nested viewholder classes are static. E.g. look at the notorious LayoutParams hierarchy, which is built exactly the same way: a class inherits another class and then their static nested classes have corresponding inheritance relationship.
    It looks like the circularity comes rather from the visibility scope issue. ModelViewHolder may extend ViewHolder only as it gets to know it after the outer ModelAdapter inherits BaseAdapter's visibility scope. Meanwhile ModelAdapter cannot inherit BaseAdapter until ModelViewHolder class is initialised as it needs for the generic parameter. On the other hand, ModelViewHolder is a static nested class and doesn't technically depend on its outer class.

    Thus, the solution is to fully qualify the ViewHolder's name when declaring ModelViewHolder. Note the extends BaseAdapter.ViewHolder part in the snippet below. This way, ModelViewHolder doesn't need to use ModelAdapter's scope to know about ViewHolder.

    ModelAdapter.java

    public class ModelAdapter extends BaseAdapter<Model, ModelAdapter.ModelViewHolder> {
        public ModelAdapter(Context context, int resource, Collection<Model> collection) {
            super(context, resource, collection);
            // typical constructor logic
        }
    
        public static class ModelViewHolder extends BaseAdapter.ViewHolder {
            // custom defined logic
        }
    }
    

    A note about Android Studio: Even though the issue itself isn't related to Android Studio, I ran into it by using AS's "Copy class" feature (using AS 3.0). While copying, it "simplified" the code for me, removing the fully qualified name. So, watch out for AS's smartness!

    0 讨论(0)
提交回复
热议问题