我正在嘗試使用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()
工作正常。