Изменение приоритета потока не имеет эффекта - PullRequest
13 голосов
/ 26 января 2012

Я пытаюсь изменить приоритет основного потока, используя android.os.Process.setThreadPriority(). У меня есть сообщения журнала до и после изменения приоритета, вот код:

public class TestActivity extends Activity {
    public final String TAG="TestActivity";
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        int tid=(int)Thread.currentThread().getId();
        Log.d(TAG,"priority before change = " + android.os.Process.getThreadPriority(tid));
        Log.d(TAG,"priority before change = "+Thread.currentThread().getPriority());
        android.os.Process.setThreadPriority(android.os.Process.THREAD_PRIORITY_DISPLAY);
        Log.d(TAG,"priority after change = " + android.os.Process.getThreadPriority(tid));
        Log.d(TAG,"priority after change = " + Thread.currentThread().getPriority());
    }
}

И я получаю следующий вывод:

priority before change (getThreadPriority) = 0
priority before change (currentThread().getPriority) = 5
priority after change (getThreadPriority) = 0
priority after change (currentThread().getPriority) = 5

Это означает, что приоритет не изменился, какой бы метод я не использовал для его оценки. android.os.Process.THREAD_PRIORITY_DISPLAY = -4, поэтому после изменения мой выход должен быть равен -4, почему он остается прежним? Почему android.os.Process.setThreadPriority() не имеет эффекта?

P.S. Я читал документы Google о темах, но не обнаружил проблем, объясняющих разницу между android.os.Process.getThreadPriority() и Thread.currentThread().getPriority(). Почему эти методы возвращают разные значения?

P.P.S. Thread.currentThread().setPriority() отлично работает.

1 Ответ

11 голосов
/ 22 февраля 2012

Вы используете неправильный ThreadID для проверки.

Чтобы получить правильный идентификатор, вы должны использовать android.os.Process.myTid ();

Фиксированный код:

package mypackage.test;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class TestActivity extends Activity {
    public final String TAG="TestActivity";
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        int tid=android.os.Process.myTid();

        Log.d(TAG,"priority before change = " + android.os.Process.getThreadPriority(tid));
        Log.d(TAG,"priority before change = "+Thread.currentThread().getPriority());
        android.os.Process.setThreadPriority(android.os.Process.THREAD_PRIORITY_DISPLAY);
        Log.d(TAG,"priority after change = " + android.os.Process.getThreadPriority(tid));
        Log.d(TAG,"priority after change = " + Thread.currentThread().getPriority());
    }
}

Вывод журнала:

priority before change = 0
priority before change = 5
priority after change = -4
priority after change = 5

Для дальнейшей справки:

http://developer.android.com/reference/android/os/Process.html#myTid()

...