2012-01-26 2 views
12

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

ответ

11

Вы используете неправильный 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()

Смежные вопросы