【问题标题】:Android Studio tutorial app crashesAndroid Studio 教程应用程序崩溃
【发布时间】:2018-03-16 17:30:02
【问题描述】:

我知道这个问题has been askedbefore,但是由于我的 Android Studio 示例教程应用程序是使用年轻 3 年的 API 编译的,并且错误看起来有不同的原因,我认为有足够的理由重新询问它.

我一直在密切关注 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
    }
}

这是 logcat 与虚拟 Nexus 5X 的摘录,这与我在 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 显示此提示:

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

当我将这一行改写为 ...

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

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

【问题讨论】:

    标签: android kotlin


    【解决方案1】:

    试试这样。您在创建活动之前调用意图。让我知道它是否有帮助。也看看这里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
    
        }
    
    
    }
    

    【讨论】:

    • 是的,谢谢,确实有效。我根本没有注意到这两个变量必须在 onCreate 的域内分配。过失。
    • 很高兴听到它有帮助。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-10-27
    • 2015-05-03
    • 2017-07-22
    • 2015-12-05
    • 1970-01-01
    相关资源
    最近更新 更多