首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >onDestroy()方法不工作

onDestroy()方法不工作
EN

Stack Overflow用户
提问于 2012-02-03 16:09:06
回答 3查看 5.8K关注 0票数 0

首先,当我的应用程序关闭时,我使用了onDestroy()方法,如下所示。

代码语言:javascript
复制
@Override
protected void onDestroy()
{
    super.onDestroy();
    mediaPlayer.stop();
    mediaPlayer2.stop();
}

但它会导致运行时错误。我使用了onStop()方法,并解决了问题。但是我想知道为什么onDestroy不能工作?你能解释一下吗。

代码语言:javascript
复制
@Override
protected void onStop()
{
    super.onStop();
    mediaPlayer.stop();
    mediaPlayer2.stop();
}

对我的代码做了一些修改,现在没有错误,当我用onDestroy()更改onStop()时,我无法理解它是如何工作的。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-02-03 16:12:24

我的猜测是,您的mediaPlayer变量在到达onDestroy之前被空出(销毁)。你看到的错误是一个空例外。

在使用mediaPlayer之前,您可以将您的内容放回ondestroy方法中,并添加一个简单的空测试:

代码语言:javascript
复制
@Override protected void onDestroy() {
    super.onDestroy();

    if (mediaPlayer != null) {
      mediaPlayer.stop();
      mediaPlayer2.stop();
    } 
 }
票数 3
EN

Stack Overflow用户

发布于 2012-02-03 16:16:38

重新设置代码:

代码语言:javascript
复制
@Override 
 protected void onDestroy() 
 { 
    mediaPlayer.stop(); 
    mediaPlayer2.stop(); 
    super.onDestroy(); 
 } 

首先销毁对象,然后从对象中检索数据,这是不可能的。因此,首先,检索所有数据,然后调用super.onDestroy();

这应该可以解决。

票数 2
EN

Stack Overflow用户

发布于 2012-02-03 16:17:04

你试过另一种方式了吗?

代码语言:javascript
复制
@Override
protected void onDestroy()
{
    mediaPlayer.stop();
    mediaPlayer2.stop();
    super.onDestroy(); //finally
}

我确实喜欢这个我的申请。我想你应该看看这些回调是如何工作的。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9131704

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档