Android Studio教程应用程序崩溃

时间:2018-03-16 17:30:02

标签: android kotlin

我知道这个问题has been asked before,但由于我的Android Studio示例教程应用程序使用了3年的API进行编译,并且错误看起来有不同的原因,我认为它是&#39 ;有理由重新问起来。

我正在密切关注Android SDK指南构建您的第一个应用程序,我在Kotlin中完成所有操作,而不是Java。我也不同于建议的兼容级别(我使用的是Android 7.0 API 24)。该应用程序编译正常(只有1个警告回合 NDK缺少"平台"目录)。无论是在使用Android 7.0 API 24的Galaxy S6上运行还是在使用API​​ 27的虚拟Nexus 5X上运行,应用程序都会在launching the Second activity显示消息时崩溃。

有两个活动:主活动,其中包含一个包含一些文本字段的EditText,以及一个按钮,用于将意图中的文本作为EXTRA_MESSAGE发送到应该显示它的第二个活动。

主要活动的代码:

package com.altran.tutorialapp

import android.content.Intent
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.view.View
import android.widget.EditText

const val TUTORIAL_EXTRA_MESSAGE = "com.altran.tutorialapp.MESSAGE"

class MainActivity : AppCompatActivity() {

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

    //** Called when the user taps the send button */
    fun sendMessage(view: View) {
        val writtenTextView = findViewById<EditText>(R.id.editText)
        val message = writtenTextView.text.toString()
        val intent = Intent(this, DisplayMessageActivity::class.java).apply {
            putExtra(TUTORIAL_EXTRA_MESSAGE, message)
        }
        startActivity(intent)
    }
}

第二项活动的代码:

package com.altran.tutorialapp

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.widget.TextView


class DisplayMessageActivity : AppCompatActivity() {

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

    // Get the intent that started this activity and extract the string
    val message = intent.getStringExtra(TUTORIAL_EXTRA_MESSAGE)

    // Capture this layout's TextView and set its string to the string of the EXTRA
    val textView = findViewById<TextView>(R.id.textView).apply {
        text = message
    }
}

以下是使用虚拟Nexus 5X的logcat的摘录,这也是我在Galaxy S6的正确错误报告中得到的同样的错误

03-16 18:14:20.786 3843-3843/com.altran.tutorialapp E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.altran.tutorialapp, PID: 3843
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.altran.tutorialapp/com.altran.tutorialapp.DisplayMessageActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.getStringExtra(java.lang.String)' on a null object reference
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2679)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
    at android.app.ActivityThread.-wrap11(Unknown Source:0)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
    at android.os.Handler.dispatchMessage(Handler.java:106)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6494)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.getStringExtra(java.lang.String)' on a null object reference
    at com.altran.tutorialapp.DisplayMessageActivity.<init>(DisplayMessageActivity.kt:16)
    at java.lang.Class.newInstance(Native Method)
    at android.app.Instrumentation.newActivity(Instrumentation.java:1174)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2669)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856) 
    at android.app.ActivityThread.-wrap11(Unknown Source:0) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589) 
    at android.os.Handler.dispatchMessage(Handler.java:106) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6494) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807) 

但我不知道如何防止这种情况发生。堆栈跟踪指向行

val message = intent.getStringExtra(TUTORIAL_EXTRA_MESSAGE)

和Android Studio显示了这个提示:

  

声明具有从平台调用中推断出的类型,这可以导致   未经检查的可空性问题。明确指定类型为nullable或   非空的。此检查报告功能和   具有平台类型的属性。为了防止意外   错误,应明确声明类型。

当我将该行重写为...

private val message: String = intent.getStringExtra(TUTORIAL_EXTRA_MESSAGE)

......发生同样的错误。我还可以做些什么?这是我的第一个应用程序和第一个Kotlin代码,所以请保持温和。

1 个答案:

答案 0 :(得分:3)

试试这样。您在创建活动之前调用intent。如果有帮助,请告诉我。另请查看此处https://kotlinlang.org/docs/tutorials/android-plugin.html您可以使用kotlin视图绑定而不是findViewById。

class DisplayMessageActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_display_message)
        //Get the intent that started this activity and extract the string
        val message = intent.getStringExtra(TUTORIAL_EXTRA_MESSAGE)

        // Capture this layout's TextView and set its string to the string of the EXTRA
        val textView = findViewById<TextView>(R.id.textView)
        textView.text = message

    }


}