Estoy intentando cambiar la prioridad del subproceso principal usando android.os.Process.setThreadPriority()
. Tengo registrar mensajes antes y después de cambiar la prioridad, aquí está el código:Cambiar prioridad de subproceso no tiene un efecto
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());
}
}
Y consigo el siguiente resultado:
priority before change (getThreadPriority) = 0
priority before change (currentThread().getPriority) = 5
priority after change (getThreadPriority) = 0
priority after change (currentThread().getPriority) = 5
Esto significa que la prioridad no cambió, cualquiera que sea el método que utilizo para evaluar eso. android.os.Process.THREAD_PRIORITY_DISPLAY = -4
, entonces después de cambiar mi salida debe ser igual a -4, ¿por qué sigue siendo la misma? ¿Por qué android.os.Process.setThreadPriority()
no tiene ningún efecto?
P.S. Leí documentación de google sobre hilos, pero no encontré ningún problema explicando la diferencia entre android.os.Process.getThreadPriority()
y Thread.currentThread().getPriority()
. ¿Por qué estos métodos devuelven valores diferentes?
P.P.S. Thread.currentThread().setPriority()
funciona bien.