Parameter specified as non-null is null: method ko

2020-07-02 08:35发布

I got this error just after converted the adapter code to Kotlin:

java.lang.IllegalArgumentException: Parameter specified as non-null is null: method kotlin.jvm.internal.Intrinsics.checkParameterIsNotNull, parameter convertView
    at ...MyAdapter.getView(Unknown Source:35)
    at android.widget.HeaderViewListAdapter.getView(HeaderViewListAdapter.java:220)
    at android.widget.AbsListView.obtainView(AbsListView.java:2366)

The error fires when inflating the row:

class LegalAdapter internal constructor(private val activity: Activity, private val list: ArrayList<Item>) : BaseAdapter() {

    override fun getView(position: Int, convertView: View, parent: ViewGroup): View {

    val layoutInflater = activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater

    @SuppressLint("ViewHolder")
    val row = layoutInflater.inflate(R.layout.legal_list_item, parent, false) //exception is throw here

Apparently, some parameter that shouldn't be null is null, and kotlin check it. Problem is i can't even debug the new kotlin code.

4条回答
走好不送
2楼-- · 2020-07-02 08:40

Make convertView nullable:

convertView: View?

I'm not sure why the line number is wrong, but the stacktrace tells you where to look in the error message.

查看更多
乱世女痞
3楼-- · 2020-07-02 08:42

The getView() method is a part of the Adapter interface, and is defined in Java. Documentation here. The important part is this note about the convertView parameter:

View: The old view to reuse, if possible. Note: You should check that this view is non-null and of an appropriate type before using.

This means that it's quite valid for the framework to pass null values for convertView to this method (meaning that you need to create a new view and return that, rather than recycling an old view).

In turn, this means that the Kotlin definition of convertView must be of type View?, not just View. So change your function signature to this:

override fun getView(position: Int, convertView: View?, parent: ViewGroup): View
查看更多
萌系小妹纸
4楼-- · 2020-07-02 08:49

Change your convertView in getView from non-null to nullable

override fun getView(position: Int, convertView: View, parent: ViewGroup): View {

to

override fun getView(position: Int, convertView: View?, parent: ViewGroup): View {
查看更多
三岁会撩人
5楼-- · 2020-07-02 08:53

All correct solutions are already posted above. Just one more with some code and ViewBinding:

class SpinnerAdapter(
      context: Context,
      private val items: List<YourModel>
) : BaseAdapter() {

private var layoutInflater: LayoutInflater = LayoutInflater.from(context)

override fun getView(i: Int, convertView: View?, viewGroup: ViewGroup): View {
    return if (convertView != null) {
        convertView
    } else {
        val view = layoutInflater.inflate(R.layout.item_spinner, null)
        val binding = ItemSpinnerBinding.bind(view)
        val item = items[i]
        binding.name.text = item.name
        view
    }
}

//more overridde methods
}

Where my R.layout.item_spinner has a TextView with an Id called "name".

查看更多
登录 后发表回答