访问被破坏活动的数据意味着我有内存泄漏



我创建了一个接口,其中包含对从活动实例化的接口的引用。

这就是接口:

public interface Calback {
void fun();
}

这是实例化calback并将其绑定到sincktask的活动。

public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

final TextView txt = findViewById(R.id.helloTxtv);
txt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Calback call = new Calback() {
@Override
public void fun() {
Log.d("tag","text of destroyed activity: "+((TextView)findViewById(R.id.helloTxtv)).getText());
}
};
Worker worker = new Worker(call);            
worker.execute();
}
});

}
}

奇怪的是,使用calback,即使活动被破坏,我也可以访问textview。

这是来自asynctask:的代码

public class Worker extends AsyncTask<Void, Void, Void> {
private final Calback call;
public Worker(Calback call) {
this.call = call;
}

@Override
protected Void doInBackground(Void... voids) {
try {
sleep(5000);
Log.d("tag","done");
} catch (InterruptedException e) {
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
call.fun();

}
}

为了确保活动被破坏,我只是旋转了屏幕。(但在开始另一项活动并完成当前活动后,我得到了相同的结果(

这是日志结果。

附言:我用过Android Studio 3.0

如果您能够在父Activity被销毁后访问TextView的文本,则表示内存泄漏。

然而,我不相信这就是这里正在发生的事情。我认为更有可能的是,要么活动没有被破坏,要么活动的状态持续存在,而你现在看到的是新(转世(活动中的状态。

为什么?因为,回调似乎是通过文本视图的onClick侦听器调用的。只有当特定的文本视图仍然可见时,才会发生这种情况。如果它是已销毁活动的一个组件,则它不可见。

相关内容

  • 没有找到相关文章

最新更新