我创建了一个接口,其中包含对从活动实例化的接口的引用。
这是界面:
public interface Calback {
void fun();
}
这是实例化校准并将其绑定到asincktask的活动。
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();
}
});
}
}
奇怪的是,即使活动被破坏,使用该回调我也可以访问textview。
这是来自asyncktask的代码:
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();
}
}
为确保该活动被销毁,我刚刚旋转了屏幕。(但是在开始另一项活动并完成当前活动后,我得到了相同的结果)
这是the log的结果。
PS:我使用过Android Studio 3.0
答案 0 :(得分:0)
如果在父TextView
被销毁后能够访问Activity
的文本,则内存泄漏。
但是,我不确信这是怎么回事。我认为很有可能是该活动没有被破坏,或者该活动的状态是持久的,而您现在正在查看新的(转生的)活动中的状态。
为什么?因为,似乎回调是通过onClick侦听器为文本视图调用的。只有在 specific 文本视图仍然可见的情况下,才会发生这种情况。如果它是被破坏活动的组成部分,则看不到。