提问者:小点点

类型与Kotlin通用适配器不匹配


我正在尝试创建一个基适配器类,它可以被所有其他的RecycerView适配器扩展,因为它们之间没有太大的差别。

下面是我的BaseAdapter类:

private const val IS_EMPTY = 0
private const val IS_NOT_EMPTY = 1

abstract class BaseAdapter<T>(
    @LayoutRes open val layoutId: Int,
    private val dataList: ArrayList<T>?
) : RecyclerView.Adapter<BaseViewHolder<Any>>() {

    abstract fun setViewHolder(parent: ViewGroup): BaseViewHolder<Any>
    abstract fun bind(containerView: View, item: T)

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): BaseViewHolder<Any> {
        return setViewHolder(parent)
    }

    override fun onBindViewHolder(holder: BaseViewHolder<Any>, position: Int) {
        bind(holder.containerView, dataList!![position])
    }

    override fun getItemCount(): Int = dataList!!.size

    override fun getItemViewType(position: Int): Int = if (dataList!!.size == 0) IS_EMPTY else IS_NOT_EMPTY
}

下面是我的BaseViewHolder类:

abstract class BaseViewHolder<in T: Any>(override val containerView: View) : RecyclerView.ViewHolder(containerView),
    LayoutContainer

我试图在其中实现的类(LessonsRecyclerViewAdapter)的片段:

override fun setViewHolder(parent: ViewGroup): BaseViewHolder<Any> {
        val view = LayoutInflater.from(parent.context).inflate(layoutId, parent, false)
        return LessonsViewHolder(view)
        //Type mismatch: Required: BaseViewHolder<Any> Found: LessonsRecyclerViewAdapter.LessonsViewHolder
    }

LessonsViewHolder只是一个空类,扩展了BaseViewHolder:

class LessonsViewHolder(override val containerView: View): BaseViewHolder<Lesson>(containerView)

LessonsViewHolder扩展BaseViewHolder时,为什么会出现类型不匹配错误?


共1个答案

匿名用户

这是因为您混合了Tany类型,请尝试以下操作:
BaseViewHolder

abstract class BaseViewHolder<T>(override val containerView: View) :
    RecyclerView.ViewHolder(containerView),
    LayoutContainer

BaseViewAdapter

abstract class BaseAdapter<T>(
    @LayoutRes open val layoutId: Int,
    private val dataList: ArrayList<T>?
) : RecyclerView.Adapter<BaseViewHolder<T>>() {

    abstract fun setViewHolder(parent: ViewGroup): BaseViewHolder<T>
    abstract fun bind(containerView: View, item: T)

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): BaseViewHolder<T> {
        return setViewHolder(parent)
    }

    override fun onBindViewHolder(holder: BaseViewHolder<T>, position: Int) {
        bind(holder.containerView, dataList!![position])
    }

    override fun getItemCount(): Int = dataList!!.size

    override fun getItemViewType(position: Int): Int =
        if (dataList!!.size == 0) IS_EMPTY else IS_NOT_EMPTY
}