13

を使用してメインスレッドの優先度を変更しようとしてい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()効果がないのですか?

android.os.Process.getThreadPriority()PS スレッドに関する Google ドキュメントを読みましたが、との違いを説明する問題に遭遇しませんでしたThread.currentThread().getPriority()。これらのメソッドが異なる値を返すのはなぜですか?

PPSThread.currentThread().setPriority()は正常に動作します。

4

1 に答える 1

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()

于 2012-02-22T12:07:22.983 に答える