我创建了一个接口,其中包含对从活动实例化的接口的引用。
这就是接口:
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侦听器调用的。只有当特定的文本视图仍然可见时,才会发生这种情况。如果它是已销毁活动的一个组件,则它不可见。