Я пытаюсь изменить приоритет основного потока, используя 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 ()
работает нормально.