0

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

这是界面:

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();


    }
}

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

这是日志结果。

PS:我用过Android Studio 3.0

4

1 回答 1

0

如果您能够TextView在父Activity级被销毁后访问文本,那么您就有内存泄漏。

但是,我不相信这就是这里发生的事情。我认为更有可能是活动没有被销毁,或者活动的状态是持久的,而您现在正在查看新(转世)活动中的状态。

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

于 2018-07-22T06:19:28.620 回答