2

我是新来的,我有一个关于 android 服务的问题。由于某种原因,我的服务没有开始。并且没有在 logcat 中给出任何错误。我用了

startService(new Intent(getApplicationContext(),MyResultsService.class));

在主活动中调用服务 (MyResultsService.class)。

另外,这是 MyResultsService.class:

package com.example.myapp;

import android.app.Service;
import android.content.Intent;
import android.os.IBinder;
import android.util.Log;

public class MyResultsService extends Service{
    public UpdateMyResults updater;
    public boolean stopThread = false;

    @Override
    public void onCreate() {
        // TODO Auto-generated method stub
        super.onCreate();
        Log.d(getPackageName(), "Created MyResultsService");
    }

    @Override
    public synchronized int onStartCommand(Intent intent, int flags, int startId) {
        // TODO Auto-generated method stub
        Log.d(getPackageName(), "Starting...");
        if (!updater.isAlive()){
            updater = new UpdateMyResults();
            Log.d(getPackageName(), "New updater thread...");
        }
        return super.onStartCommand(intent, flags, startId);
    }

    @Override
    public synchronized void onDestroy() {
        // TODO Auto-generated method stub
        stopThread = true;
        Log.d(getPackageName(), "Destroying MyResultsService");
        try {
            updater.join();
            Log.d(getPackageName(), "Closed updater thread");
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        super.onDestroy();

    }

    @Override
    public IBinder onBind(Intent intent) {
        // TODO Auto-generated method stub
        return null;
    }

    private class UpdateMyResults extends Thread{

        static final long DELAY = 30000;
        @Override
        public void run() {
            while (!stopThread){
                try {
                    //Do stuff and pause
                    Log.d(getName(), "Running");
                    Thread.sleep(DELAY);
                } catch (InterruptedException e) {
                    // Interrupt
                    e.printStackTrace();
                }
            }//end while
        }//end run
    }//end UpdateMyResults
}

我的 xml 清单:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.myapp"
    android:versionCode="1"
    android:versionName="1.0">

    <uses-sdk android:minSdkVersion="14" android:targetSdkVersion="17" />

    <application
        android:label="MyApp"
        android:icon="@drawable/ic_launcher"
        android:theme="@android:style/Theme.Holo.Light">

        <activity
            android:name=".MainActivity"
            android:label="My App">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>      
        </activity>

        <service android:enabled="true" android:name="com.example.myapp.MYRESULTSSERVICE" />

    </application>

</manifest>

任何帮助将不胜感激,谢谢!

4

5 回答 5

14

中的名称<service android:enabled="true" android:name="com.example.myapp.MYRESULTSSERVICE" />必须与您的班级完全匹配。尽量不要使用全部大写。

于 2013-07-15T14:43:16.243 回答
0

尝试在清单文件中使用以下内容:

<service android:enabled="true" android:name="com.example.myapp.MyResultsService"/> 
于 2013-07-15T14:44:59.953 回答
0

将清单中的服务标签更改为以下内容。

<service android:enabled="true" android:name="com.example.myapp.MyResultsService" />
于 2013-07-15T14:45:36.383 回答
0

您的清单有错误的服务名称。但您的MYRESULTSSERVICE服务类名称是MyResultsService. 尝试从 更改MYRESULTSSERVICEMyResultsService

于 2013-07-15T15:07:57.697 回答
0
Line 23, you are calling a method on a variable (updater) that has not been initialized yet, causing a NPE. – Alex Fu Jul 15 '13 at 16:03

你还没有开始线程。

于 2016-10-26T10:25:13.687 回答