0

アプリで AsyncTask を使用していますが、コードは次のとおりです。

protected Void doInBackground(Void... params) {
        // Get the current thread's token

        try {
            synchronized (this) {
                Looper.prepare();                   
                if (isCancelled()) {

                } else {                        
                    gpsCoordinates = new GetGpsCoordinates();   
                    location = gpsCoordinates.getLocation(context);

                    int counter = 0;
                    while (counter <= 4) {
                        this.wait(850);
                        counter++;
                        publishProgress((int) (counter) * 50);
                    }
                }
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        return null;
    }

およびGetGpsCoordinates.class、

public Location getLocation(Context mContext) {
    try {
        locationManager = (LocationManager) mContext
                .getSystemService(LOCATION_SERVICE);
        Criteria criteria = new Criteria();
        criteria.setAccuracy(Criteria.ACCURACY_FINE);

        // getting GPS status
        isGPSEnabled = locationManager
                .isProviderEnabled(LocationManager.GPS_PROVIDER);

        // getting network status
        isNetworkEnabled = locationManager
                .isProviderEnabled(LocationManager.NETWORK_PROVIDER);

        if (!isGPSEnabled && !isNetworkEnabled) {
            // no network provider is enabled
        } else {
            this.canGetLocation = true;
            // First get location from Network Provider
            Log.d("","collecting lat,lng details");
            if (isNetworkEnabled) {             
                locationManager.requestLocationUpdates(
                        LocationManager.NETWORK_PROVIDER,
                        MIN_TIME_BW_UPDATES,
                        MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                Log.d("Network", "Network");
                if (locationManager != null) {
                    location = locationManager
                            .getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
                    if (location != null) {
                        latitude = location.getLatitude();
                        longitude = location.getLongitude();
                    }
                }
            }
            // if GPS Enabled get lat/long using GPS Services
            if (isGPSEnabled) {
                if (location == null) {
                    locationManager.requestLocationUpdates(
                            LocationManager.GPS_PROVIDER,
                            MIN_TIME_BW_UPDATES,
                            MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                    Log.d("GPS Enabled", "GPS Enabled");
                    if (locationManager != null) {
                        location = locationManager
                                .getLastKnownLocation(LocationManager.GPS_PROVIDER);
                        if (location != null) {
                            latitude = location.getLatitude();
                            longitude = location.getLongitude();

                        }
                    }
                }
            }
        }

    } catch (Exception e) {
        e.printStackTrace();
    }

    return location;
}

looper.prepare() を使用すると例外が発生します。これは私のlogcatです。

 06-05 17:26:16.410: E/AndroidRuntime(19075): java.lang.RuntimeException: An error occured while executing doInBackground()
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at android.os.AsyncTask$3.done(AsyncTask.java:200)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:274)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.FutureTask.setException(FutureTask.java:125)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at  java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:308)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.FutureTask.run(FutureTask.java:138)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.lang.Thread.run(Thread.java:1019)
 06-05 17:26:16.410: E/AndroidRuntime(19075): Caused by: java.lang.RuntimeException: Only one Looper may be created per thread
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at android.os.Looper.prepare(Looper.java:74)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at com.bu.PropertySearchTypes.CameraSearch$LoadViewTask.doInBackground(CameraSearch.java:125)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at com.bu.PropertySearchTypes.CameraSearch$LoadViewTask.doInBackground(CameraSearch.java:1)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at android.os.AsyncTask$2.call(AsyncTask.java:185)
 06-05 17:26:16.410: E/AndroidRuntime(19075):   at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)

onSensorChanged() でこの asynctask を呼び出しています。つまり、センサー値が変更されるたびに、このスレッドが実行されます。私を助けてください。私はこの例外に非常に不満を感じています。助けてくれてありがとう!!

4

1 に答える 1

1

新しいスレッドで新しいルーパーを開始する必要があります。例外には、この情報が含まれています。正しい使用法については、次の投稿をご覧ください: Looper の目的と使用方法は?

しかし、本当の問題は、それが本当に必要かどうかです。Handler を開始する場合に必要です。あなたがそれを必要としているかどうかはわかりませんが、あなたがそれを必要としている場合でも、Looper も処理する特別なHandlerThreadクラスがあります。

于 2013-06-05T12:14:19.757 に答える