【问题标题】:JobScheduler.schedule(job) is not starting the JobServiceJobScheduler.schedule(job) 没有启动 JobService
【发布时间】:2016-08-05 19:15:14
【问题描述】:

我正在使用 lib 让 JobScheduler 在预棒棒糖设备上工作。我正在使用棒棒糖设备。问题是 mJobScheduler.schedule(job) 应该启动我的作业服务,但它没有启动。此外,当我包含 .setPeriodic(2000) 方法时,应用程序会因此崩溃

堆栈跟踪。

08-06 00:37:06.729 19693-19693/? E/AndroidRuntime: FATAL EXCEPTION: main
                                               Process: rishabh.example.com.myapplication, PID: 19693
                                               java.lang.RuntimeException: Unable to start activity ComponentInfo{rishabh.example.com.myapplication/rishabh.example.com.myapplication.MainActivity}: java.lang.IllegalArgumentException: Can't call setOverrideDeadline() on a periodic job.
                                                   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2339)
                                                   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413)
                                                   at android.app.ActivityThread.access$800(ActivityThread.java:155)
                                                   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317)
                                                   at android.os.Handler.dispatchMessage(Handler.java:102)
                                                   at android.os.Looper.loop(Looper.java:135)
                                                   at android.app.ActivityThread.main(ActivityThread.java:5343)
                                                   at java.lang.reflect.Method.invoke(Native Method)
                                                   at java.lang.reflect.Method.invoke(Method.java:372)
                                                   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905)
                                                   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)
                                                Caused by: java.lang.IllegalArgumentException: Can't call setOverrideDeadline() on a periodic job.
                                                   at me.tatarka.support.job.JobInfo$Builder.build(JobInfo.java:477)
                                                   at rishabh.example.com.myapplication.MainActivity.constructJob(MainActivity.java:30)
                                                   at rishabh.example.com.myapplication.MainActivity.onCreate(MainActivity.java:19)
                                                   at android.app.Activity.performCreate(Activity.java:6010)
                                                   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1129)
                                                   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2292)
                                                   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413) 
                                                   at android.app.ActivityThread.access$800(ActivityThread.java:155) 
                                                   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317) 
                                                   at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                   at android.os.Looper.loop(Looper.java:135) 
                                                   at android.app.ActivityThread.main(ActivityThread.java:5343) 
                                                   at java.lang.reflect.Method.invoke(Native Method) 
                                                   at java.lang.reflect.Method.invoke(Method.java:372) 
                                                   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905) 
                                                   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700) 

我的主要活动

public class MainActivity extends AppCompatActivity {

JobScheduler mJobScheduler;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mJobScheduler=JobScheduler.getInstance(this);
    constructJob();
}

private void constructJob() {

    JobInfo job = new JobInfo.Builder(0 /*jobid*/, new ComponentName(this,MyService.class))
            .setMinimumLatency(1000)
            .setOverrideDeadline(2000)
            .setRequiredNetworkType(JobInfo.NETWORK_TYPE_UNMETERED)
            .setRequiresCharging(true)
            .setPeriodic(2000)
            .build();



    mJobScheduler.schedule(job);

}
}

我的服务类

public class MyService extends JobService {
@Override
public boolean onStartJob(JobParameters params) {
    Toast.makeText(getApplicationContext(),"onStartjob",Toast.LENGTH_SHORT).show();
    Log.i("tag","onstartjob");
    return false;
}

@Override
public boolean onStopJob(JobParameters params) {
    return false;
}
}

我的清单文件

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="rishabh.example.com.myapplication">
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <service android:name=".MyService"
        android:permission="android.permission.BIND_JOB_SERVICE"
        android:exported="true">

    </service>
</application>

【问题讨论】:

    标签: android android-jobscheduler


    【解决方案1】:

    您不能同时使用setPeriodic()setOverrideDeadline()

    因为在周期性作业上设置此属性没有意义,所以在调用 build() 时这样做会引发 IllegalArgumentException。

    见:JobInfo.Builder javadoc

    【讨论】:

    • 好的,我删除了 setOverrideDeadline() 属性,应用程序运行没有错误,但仍然没有调用 onStartJob() 方法! @koral
    • 该库似乎有一个类似的unresolved issue。项目是no longer maintained,所以它可能永远不会修复。
    • 我想每 5 秒执行一次任务。有什么替代方法? @koral
    • 对于这么小的间隔Handler 应该是合适的。见A flowchart for background work, alarms, and your Android app Pro-tip
    • 您需要一个服务器(或云服务帐户)才能使 GCM(或其继任者 - FCM)工作,并且设备需要工作网络连接。它旨在在推送消息到达时触发操作(通常在与 GCM 连接的 CMS 上输入新内容后),而不是重复工作。
    猜你喜欢
    • 2019-02-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-03-10
    • 1970-01-01
    • 1970-01-01
    • 2021-08-16
    相关资源
    最近更新 更多