3

我正在创建许多表面视图实例来查看一些对象,但一次创建一个实例,然后调用 surfaceDestroyed。但是我每次在surfacecreated上创建的线程都被添加到主线程组中。

虽然我正在中断和取消它,但它仍然驻留在主线程组中并创建低内存异常。

代码片段:构造函数

public class MsurfaceView extends SurfaceView implements
        SurfaceHolder.Callback {
_thread = new mThread(this);
   _thread.setName("mThread");


@Override
    public void surfaceCreated(SurfaceHolder holder) {

        if (!_thread.isAlive()) {
            _thread = new BreedingThread(this);
        }

        _thread.setRunning(true);
        _thread.start();

    }





@Override
    public void surfaceDestroyed(SurfaceHolder holder) {
        Log.d("mThread", "Surface Destroyed Called");
        getHolder().removeCallback(this);
        getHolder().addCallback(null);

        boolean retry = true;
        _thread.setRunning(false);

        while (retry) {
            try {
                _thread.interrupt();
                _thread.getThreadGroup().interrupt();
                _thread.join();
                retry = false;
            } catch (InterruptedException e) {
                Log.d("mThread", "Interrupted");
                // pass interrupt exception
                Thread.currentThread().interrupt(); 
                Log.d("mThread", "b4 threadGroupInterrupted");
                _thread.getThreadGroup().interrupt();
                _thread.getThreadGroup().list();//this shows thread is in //list
                _thread = null;
                break;
            }
        }
    }

UPDATE Thread.list 函数显示我的中断和空线程仍在线程组中

06-10 15:22:52.780: INFO/System.out(1814): java.lang.ThreadGroup[name=main,maxPriority=10]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[main,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-2,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Binder Thread #1,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Binder Thread #2,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[FlurryAgent,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[AsyncTask #1,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[AsyncTask #2,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-17,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-38,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Timer-2,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-53,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-286,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-327,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-359,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[mThread,5,main]
06-10 15:22:52.780: INFO/System.out(1814):     Thread[Thread-409,5,main]

如何删除它们?

4

2 回答 2

1

有些东西要寻找。

  1. 您只在 catch 块内调用 _thread = null - 这意味着如果从不抛出异常,它将不会被设置为 null 。将其移动到 finally 块中。
  2. 该异常可能永远不会被抛出。调用 Thread.interrupt() 不会抛出它。这会将线程的中断标志设置为真。整个 while 循环相当奇怪,您可能应该重新编写它。
  3. 您正在将此实例传递给 BreedingThread。确保该对象不会永远持有对您的表面视图的引用
  4. 简单地调用表面视图销毁方法并不意味着如果某些东西仍然持有对它的引用,则该引用将被删除(例如我在 3 中提到的)。
于 2011-06-10T10:31:09.497 回答
0

当您调用“新线程”并且未指定组时,线程将被添加到与调用者相同的组中(即Thread.currentThread().getThreadGroup())。在您的情况下,这就是导致您的线程被添加到“主”线程组的原因。要更改该行为,请使用new Thread(group, this)指定组。

于 2017-03-28T16:42:26.623 回答