2012-01-26 8 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, 내 ouput을 변경 한 후 -4와 같아야합니다. 왜 동일하게 유지됩니까? 왜 android.os.Process.setThreadPriority()이 효과가 없습니까?

P. 스레드에 대한 Google 워드 프로세서를 읽었지만 android.os.Process.getThreadPriority()Thread.currentThread().getPriority() 사이의 차이점을 설명하는 문제를 발견하지 못했습니다. 이 메소드가 다른 값을 반환하는 이유는 무엇입니까?

P.P.S. Thread.currentThread().setPriority()이 정상적으로 작동합니다.

답변

11

수표에 잘못된 ThreadID를 사용하고 있습니다.

올바른 ID를 얻으려면 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()