【发布时间】:2020-09-30 19:13:10
【问题描述】:
这是我的接口类
interface InstallerInterface {
fun onInstallation(context: Context)
}
我在这个类中实现了接口
class FirstActivity : InstallerInterface{
override fun onInstallation(context: Context) {
*MyCode*
}
}
我尝试使用意图传递此上下文
val intent=Intent(context,SecondActivity::class.java)
intent.putExtra("NAME",name)
intent.putExtra("Callback",Interface)
context.startActivity(intent)
但是 intent.putExtra 导致了错误 Cannot resolve method 'putExtra() 。所以我在FirstActivity() 类中实现了Serializable。但这导致了错误
06-11 12:28:57.323 4042 4042 E AndroidRuntime: java.lang.RuntimeException: Parcelable encountered IOException writing serializable object (name = FirstAcitvity)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Parcel.writeSerializable(Parcel.java:1535)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Parcel.writeValue(Parcel.java:1483)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Parcel.writeArrayMapInternal(Parcel.java:732)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.BaseBundle.writeToParcelInner(BaseBundle.java:1417)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Bundle.writeToParcel(Bundle.java:1157)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Parcel.writeBundle(Parcel.java:772)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.content.Intent.writeToParcel(Intent.java:8703)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.ActivityManagerProxy.startActivity(ActivityManagerNative.java:3082)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.Instrumentation.execStartActivity(Instrumentation.java:1520)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.Activity.startActivityForResult(Activity.java:4229)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at androidx.fragment.app.FragmentActivity.startActivityForResult(FragmentActivity.java:676)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.Activity.startActivityForResult(Activity.java:4187)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at androidx.fragment.app.FragmentActivity.startActivityForResult(FragmentActivity.java:663)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.Activity.startActivity(Activity.java:4526)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.Activity.startActivity(Activity.java:4494)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at foundation.e.apps.XAPK.LaunchUtils.startInstallSplitApksActivity(LaunchUtils.kt:15)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at foundation.e.apps.XAPK.ViewUtils$installXApk$1.onCompedApks(ViewUtils.kt:57)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at foundation.e.apps.XAPK.XApkInstallUtils$installSplitApks$2.run(XApkInstallUtils.kt:191)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:751)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:95)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Looper.loop(Looper.java:154)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:6186)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: Caused by: java.io.NotSerializableException: ThirdAcivity()
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1224)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1584)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1549)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1472)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1218)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:346)
06-11 12:28:57.323 4042 4042 E AndroidRuntime: at android.os.Parcel.writeSerializable(Parcel.java:1530)
06-11 12:28:57.323 4042
我相信ThirdActivity() 实现了FirstActivity(),而我没有在ThirdAcivity 中实现Serializable。所以我在 ThirdAcitivity 中实现了 Serializable 。而且我在每个使用FirstAcivity 的活动上都遇到了错误。这是一个大型项目,我无法在每个 Acitivity 上实施 Serializable。
所以我改为实现Parcelable。我的代码是
@Parcelize
class FirstActivity : InstallerInterface, Parcelable{
override fun onInstallation(context: Context) {
*MyCode*
}
}
我得到了像java.lang.RuntimeException: Parcel: unable to marshal value这样的错误
我该如何修复此代码。如果没有,还有什么更好的选择。提前谢谢你
【问题讨论】:
-
为什么要将接口传递给另一个类?你能补充更多细节吗?
-
我想您想使用 SecondActivity 中的 FirstActivity 中实现的接口来监听事件?如果是这种情况,请尝试使用 startActivityForResult 方法。您甚至可以将其链接到第 3 次活动到第 1 次活动developer.android.com/training/basics/intents/result
-
如果你想在非活动类中使用上下文,那么你可以试试这个答案stackoverflow.com/questions/17917968/…
-
我想从
SecondActivity调用FirstActivity()的接口函数onInstallation()。喜欢callback.onInstallation。我无法使用intent.putExtra将接口传递给SecondActivity。主要思想是获取接口类的上下文 -
gitlab.e.foundation/DayonaJ/apps/-/commit/…。这就是我正在做的事情。我想从
InstallSplitApksActivity.kt调用Application.kt类的onInstalationComplete()(这是InstallerInterface.kt方法)
标签: android kotlin android-intent parcelable serializable