如何在观察实时数据值的同时修复“ resp”的空指针

时间:2019-03-30 08:08:31

标签: android kotlin android-livedata mutablelivedata

我的代码在视图模型中工作正常,但是当我开始使用

中的实时数据观察值时
model.d.observe(this, Observer<RespCategories> {
                r->resp=r
})
resp=r中r的

类型从RespCategories更改为RespCategories? 并且它与寻呼机适配器的参数不匹配,因此我对其进行了一些更改,例如将var resp: RespCategories转换为var resp: RespCategories? = null,因此在观察r->resp=r的值时,出现了一个新问题,即resp值为null 。如何解决该问题?

kotlin.KotlinNullPointerException   at com.example.xyz.MainActivity.showData(MainActivity.kt:83)
                      at com.example.xyz.MainActivity$fetchData$1.onResponse(MainActivity.kt:65)
  

MainActivity

class MainActivity : AppCompatActivity()
 {

    var userService: UserService = ApiUtils.getUserService()
    var dotscount: Int = 0
    lateinit var sliderDotspanel: LinearLayout
    lateinit var sectionPagerAdapter: SectionPagerAdapter
    lateinit var respCategories: RespCategories
    var resp: RespCategories? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        sliderDotspanel = findViewById(R.id.sliderdots)
        fetchData()


    }


    fun fetchData() {

        var call: Call<RespCategories>

        call = userService.getData()

        call.enqueue(object : Callback<RespCategories> {
            override fun onFailure(call: Call<RespCategories>, t: Throwable) {
                Toast.makeText(this@MainActivity, "fail", Toast.LENGTH_LONG).show()
            }

            override fun onResponse(call: Call<RespCategories>, response: Response<RespCategories>) {
                Toast.makeText(this@MainActivity, "success", Toast.LENGTH_LONG).show()
                respCategories = response.body()!!
                var dataGenerator:DataGenerator
                dataGenerator=DataGenerator()
                dataGenerator.addData(respCategories)
              //  DataGenerator.addData(respCategories)
                showData()
            }

        })

    }

    fun showData(){

        //var resp:RespCategories=DataGenerator.getData()
        val model=ViewModelProviders.of(this).get(DataGenerator::class.java)
       // var resp=model.getData()

        model.d.observe(this, Observer<RespCategories> {
                r->resp=r
        })

        if (viewPager != null) {

            sectionPagerAdapter = SectionPagerAdapter(supportFragmentManager, resp)
            viewPager.adapter = sectionPagerAdapter

            dotscount = sectionPagerAdapter.getCount()
            var dots: Array<ImageView?>? = null
            dots = arrayOfNulls(dotscount)

            for (i in 0 until dotscount) {
                dots[i] = ImageView(this@MainActivity)
                dots[i]!!.setImageDrawable(ContextCompat.getDrawable(applicationContext, R.drawable.non_active_dots))

                val params = LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT)
                params.setMargins(8, 0, 8, 0)
                sliderDotspanel.addView(dots[i], params)
            }

            dots[0]!!.setImageDrawable(ContextCompat.getDrawable(applicationContext, R.drawable.active_dots))
            viewPager.addOnPageChangeListener(object : ViewPager.OnPageChangeListener {
                override fun onPageScrolled(position: Int, positionOffset: Float, positionOffsetPixels: Int) {

                }

                override fun onPageSelected(position: Int) {
                    for (i in 0 until dotscount) {
                        dots[i]!!.setImageDrawable(ContextCompat.getDrawable(applicationContext, R.drawable.non_active_dots))

                    }

                    dots[position]!!.setImageDrawable(ContextCompat.getDrawable(applicationContext, R.drawable.active_dots))

                }

                override fun onPageScrollStateChanged(state: Int) {

                }
            })
        }

    }
}
>Datagenerator
````````````
class DataGenerator constructor(): ViewModel() {

    companion object {
       // lateinit var da:RespCategories
    //   lateinit var da:MutableLiveData<RespCategories>
    }

            val d=MutableLiveData<RespCategories>()

    fun addData(respCategories: RespCategories){
       // d=respCategories
        d.value=respCategories

    }
    fun getData():MutableLiveData<RespCategories>{
        return d
    }
}
>RespCategories
````````````
data class RespCategories constructor(

    @field:SerializedName("type")
    val type: String? = null,

    @field:SerializedName("value")
    val value: List<String?>? = null


)

  [1]: https://i.stack.imgur.com/eDAhx.png

1 个答案:

答案 0 :(得分:0)

您的代码中有错误:showData()中的观察者观察一个DataGenerator对象,但是onResponse()回调将数据发布到另一个对象。您应该

关于LiveData的类型参数可为空性的几句话。查看Observer界面:

public interface Observer<T> {
    void onChanged(@Nullable T t);
}
onChanged()方法的

参数用@Nullable注释。此方法根据LiveData类型参数可为空性来观察可为空的类型。 即使您的LiveData使用非null类型参数定义,您也可以期望null:

  • 如果您对新对象调用liveData.value,但是您可以覆盖默认的空值并设置自己的

    val d = MutableLiveData<RespCategories>().apply { value = RespCategories.DEFAULT }
    
  • 如果您的Java代码发布了空值(不禁止)